Arguments 对象

您所在的位置:网站首页 amd下一代核显性能 Arguments 对象

Arguments 对象

#Arguments 对象| 来源: 网络整理| 查看: 265

备注: 如果你编写兼容 ES6 的代码,那么优先推荐使用 剩余参数

备注: “类数组”意味着 arguments 有 长度 属性 并且属性的索引是从零开始的,但是它没有 Array的 内置方法,例如 forEach() 和 map()都是没有的。详情可以看 §Description.

arguments对象是所有(非箭头)函数中都可用的局部变量。你可以使用arguments对象在函数中引用函数的参数。此对象包含传递给函数的每个参数,第一个参数在索引 0 处。例如,如果一个函数传递了三个参数,你可以以如下方式引用他们:

js

arguments[0]; arguments[1]; arguments[2];

参数也可以被设置:

js

arguments[1] = "new value";

arguments对象不是一个 Array 。它类似于Array,但除了 length 属性和索引元素之外没有任何Array属性。例如,它没有 pop 方法。但是它可以被转换为一个真正的Array:

js

var args = Array.prototype.slice.call(arguments); var args = [].slice.call(arguments); // ES2015 const args = Array.from(arguments); const args = [...arguments];

警告: 对参数使用 slice 会阻止某些 JavaScript 引擎中的优化 (比如 V8 - 更多信息)。如果你关心性能,尝试通过遍历 arguments 对象来构造一个新的数组。另一种方法是使用被忽视的Array构造函数作为一个函数:

js

var args = arguments.length === 1 ? [arguments[0]] : Array.apply(null, arguments);

如果调用的参数多于正式声明接受的参数,则可以使用arguments对象。这种技术对于可以传递可变数量的参数的函数很有用。使用 arguments.length来确定传递给函数参数的个数,然后使用arguments对象来处理每个参数。要确定函数签名中(输入)参数的数量,请使用Function.length属性。



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3