JavaScript的函数里面的arguments只是array-like object,对象有 .lengh 属性和可以通过 [] 访问,但是确实从Object.prototype继承的。很多时候都会用 Array.prototype.slice.call(arguments) 或者 Array.from(arguments) 转成数组
假设一个函数的第一个参数是 a,当你修改 a 的值的时候,arguments[0] 也会同步变化:
(function (a) {
console.log(arguments[0] === a) // -> true
console.log(a) // -> 1
// 修改 arguments
arguments[0] = 10
console.log(a) // -> 10
// 修改参数变量
a = 20
console.log(arguments[0]) // -> 20
})(1,2)
function foo (...args) {
// 这里 args 终于是真正的 Array 了!
}
[尤雨溪](https://www.zhihu.com/question/50803453/answer/122786182)
转换成一个新数组
arguments是每个函数在运行的时候自动获得的一个近似数组的对象(传入函数的参数从0开始按数字排列,而且有length)。比如当你 func(‘a’, ‘b’, ‘c’) 的时候,func里面获得的arguments[0] 是 ‘a’,arguments[1] 是 ‘b’,依次类推。但问题在于这个arguments对象其实并不是Array,所以没有slice方法。Array.prototype.slice.call( )可以间接对其实现slice的效果,而且返回的结果是真正的Array。尤雨溪
slice 方法可以用来将一个类数组(Array-like)对象/集合转换成一个新数组。你只需将该方法绑定到这个对象上。 一个函数中的 arguments 就是一个类数组对象的例子
function list() {
return Array.prototype.slice.call(arguments);
}
var list1 = list(1, 2, 3); // [1, 2, 3]
function list() {
return [].slice.call(arguments);
}
var unboundSlice = Array.prototype.slice;
var slice = Function.prototype.call.bind(unboundSlice);
function list() {
return slice(arguments);
}
slice() 方法返回一个从开始到结束(不包括结束)选择的数组的一部分浅拷贝到一个新数组对象。且原始数组不会被修改。