1。Array.prototype:就是Array的原型,很多时候理解这个原型有点不清不楚的
其实,有点像.NET里的反射
一个类凡是通过prototype加的属性,方法,都可以在这个类的对象里找到 对象.
有时候我们也直接在某一对象添加属性方法,那么只能这个对象里找到,重新创建的对象是没有
刚刚在上一对象里添加的属性方法的
内置的类型可以通过prototype找到内置的属性方法
Array.prototype.slice这句就是访问Array的内置方法
因为Array是类名,而不是对象名,所以不能直接用Array.slice
2。接下来说slice方法,这个简单
返回一个数组的一段。arrayObj.slice(start, [end]) 参数开始索引和结束索引,结束索引可以省略
3。call方法
call([thisObj[,arg1[, arg2[, [,.argN]]]]])
调用一个对象的一个方法,以另一个对象替换当前对象
thisObj
可选项。将被用作当前对象的对象。
arg1, arg2, , argN
可选项。将被传递方法参数序列。
说明
call 方法可以用来代替另一个对象调用一个方法。call 方法可将一个函数的对象上下文从初始的上下文改变为由 thisObj 指定的新对象。
如果没有提供 thisObj 参数,那么 Global 对象被用作 thisObj。
这东西JS文档里我没找到怎么调用这个方法,功能是 调用一个对象的一个方法 自己的参数只有方法的所有者对象和要调用的方法参数,
查过资料才知道,Array.prototype.slice.call 是这么调用,只要 typesof fn ==="function" 的 fn类型都有 call 方法
伪组数元素
call 方法以另一个对象替换当前对象
thisObj 可选项。将被用作当前对象的对象。
这就是说:Array.prototype.slice.call(arguments,0) 这句里,就是把 arguments 当做当前对象
也就是说 要调用的是 arguments 的slice 方法,后面的 参数 0 也就成了 slice 的第一个参数slice(0)就是获取所有
为什么要这么调用 arguments 的slice 方法呢?就是因为 arguments 不是真的组数,typeof arguments==="Object" 而不是 "Array"
它没有slice这个方法,通过这么Array.prototype.slice.call调用,JS的内部机制应该是 把arguments对象转化为Array
因为Array.prototype.slice.call调用后,返回的是一个组数
经典例子:
<script type="text/javascript">//<![CDATA[
function classA() {
this.name='bluedestiny';
this.show = function () {
alert(this.name);
}
}
function classB() {
this.name = 'never-online';
}
var objA = new classA();
var objB = new classB();
objA.show.call(objB);
//]]></script>
跟call类似的还有 apply 方法
应用某一对象的一个方法,用另一个对象替换当前对象。
apply([thisObj[,argArray]])
参数
thisObj
可选项。将被用作当前对象的对象。
argArray
可选项。将被传递给该函数的参数数组。
说明
如果 argArray 不是一个有效的数组或者不是 arguments 对象,那么将导致一个 TypeError。
如果没有提供 argArray 和 thisObj 任何一个参数,那么 Global 对象将被用作 thisObj, 并且无法被传递任何参数。
呵呵,这么火星的功能,实在是少见啊,估计也就是JS里
两者的区别: 对于apply和call两者在作用上是相同的,但两者在参数上有区别的。
对于第一个参数意义都一样,但对第二个参数:
apply传入的是一个参数数组,也就是将多个参数组合成为一个数组传入,而call则作为call的参数传入(从第二个参数开始)。
如 func.call(func1,var1,var2,var3)对应的apply写法为:func.apply(func1,[var1,var2,var3])
同时使用apply的好处是可以直接将当前函数的arguments对象作为apply的第二个参数传入
分享到:
相关推荐
由于 `arguments` 不是真正的数组,直接调用 `arguments.slice()` 会抛出错误。但是,`Array.prototype.slice.apply(arguments)` 能够成功地创建一个新的数组,这是因为 `slice` 方法被应用于 `arguments` 对象,而...
永远不要写Array.prototype.slice.call(arguments); 以后再! 这是基于但使用Object.defineProperty(arguments.constructor.prototype, [functionName], {enumerable: false, configurable: true, value: [function...
在js中我们经常会看到Array.prototype.slice.call(arguments,0)的写法,当然,这个方法的作用也许大家都明白,那就是把类数组对象转换成一个真正的数组。关于这个方法,我说说自己的理解。 这里涉及到slice()方法和...
通过`Array.prototype.slice.call(arguments, 0)`,我们可以将`arguments`对象转化为真正的数组,从而可以使用数组的所有方法。 例如: ```javascript var slice = Array.prototype.slice; (function() { var ...
这里,`Array.prototype.slice.call` 被用来从 `arguments` 对象中提取一个子集,从索引 2(第三个参数)开始,直到结束。这将创建一个新的数组 `a`,包含参数 3 和 5,然后 `alert` 显示这个新数组。 这种技术在...
为了解决这个问题,我们可以使用 `call` 或 `apply` 方法,将 `slice` 方法应用于非数组的 `array-like` 对象,如 `arguments` 或 `NodeList`。 在实际应用中,我们有时会面临选择使用 `Array.prototype.slice` ...
`Array.prototype.slice` 是 JavaScript 中一个非常重要的方法,它用于从数组中提取一个部分,并返回一个新的数组,同时原始数组保持不变。这个方法的核心在于它的灵活性和在处理类似数组对象(array-like objects)...
var args = Array.prototype.slice.call(arguments); ``` 这行代码将 `arguments` 对象转换为真正的数组,以便可以使用数组特有的方法。 总的来说,了解并熟练运用 `Array.prototype` 的泛型应用可以提高代码的...
在ES5中,我们通常使用`Array.prototype.slice.call()`来实现这个功能,但在ES6中,我们可以直接使用`Array.from()`。例如,一个拥有`length`属性的对象,如`arguments`对象,可以通过`Array.from()`轻松转换。此外...
在IE8中,可以使用`Array.prototype.slice.call()`转换为可迭代对象,再配合for循环实现。 ```javascript if (!Array.prototype.map) { Array.prototype.map = function(callback, thisArg) { var T, A, k; if ...
- **Array.prototype.slice.call()**:这是最常用的转换方法,通过调用Array.prototype.slice方法并传入类数组对象作为上下文。例如: ```javascript var arrayLike = {0: 'a', 1: 'b', 2: 'c', length: 3}; var...
var innerArgs = Array.prototype.slice.call(arguments, 0); callback.apply(context, outerArgs.concat(innerArgs)); }; } ``` 在这个实现中,`bind`函数接收一个回调函数`callback`和一个上下文`context`作为...
`Array.prototype.slice.call(arguments, 1)`用于从`arguments`对象中获取从第二个参数开始的所有参数,并将它们转换成数组,这是因为`arguments`对象并不是一个真正的数组。 #### 4. 关于arguments对象与数组转换 ...
var args = Array.prototype.slice.call(arguments); // ... } ``` 通过理解和熟练运用以上知识点,前端开发者可以在面试中展示自己扎实的JavaScript基础,特别是对数组操作的理解和应用能力。不断学习和实践,...
var args = Array.prototype.slice.call(arguments, 1); return function F() { if (this instanceof F) { return new _this(...args, ...arguments); } return _this.apply(context, args.concat(......
2. Array.prototype.slice.call():使用数组原型上的slice方法,指定上下文为ArrayLike对象,如`Array.prototype.slice.call(arguments)`。 3. Array构造函数:利用Array构造函数也可以实现转换,如`new Array...
在JavaScript中,数组可以使用Array构造函数来创建,或使用[]快速创建,这也是首选的方法。数组是继承自Object的原型,... var nodesArr = Array.prototype.slice.call(document.forms); var argsArr = Array.pro
return self.apply(context, args.concat(Array.prototype.slice.call(arguments))); }; }; } ``` 总结起来,`Function.prototype.bind`是JavaScript中用于控制`this`的一个强大工具,它可以确保函数在任何环境...
代码如下: [removed] function fn(name){ if(typeof name === “string”){ var args = Array.prototype.slice.call( arguments, 1 ); for(var i=0;i<args.length;i++){ alert(args[i]);//结果: 111 222 ...