arguments[Symbol.iterator]()

arguments 对象的 [Symbol.iterator]() 方法实现了 arguments 对象的 可迭代协议,并允许 arguments 对象被大多数期望可迭代的语法(例如 扩展语法for...of 循环)使用。它返回一个 数组迭代器对象,它会生成 arguments 对象中每个索引的值。

此属性的初始值与 Array.prototype.values 属性的初始值相同(也与 Array.prototype[Symbol.iterator]() 相同)。

语法

js
arguments[Symbol.iterator]()

参数

无。

返回值

Array.prototype.values() 相同的返回值:一个新的 可迭代迭代器对象,它会生成 arguments 对象中每个索引的值。

示例

使用 for...of 循环迭代

请注意,您很少需要直接调用此方法。[Symbol.iterator]() 方法的存在使 arguments 对象 可迭代,并且像 for...of 循环这样的迭代语法会自动调用此方法以获取要循环的迭代器。

js
function f() {
  for (const letter of arguments) {
    console.log(letter);
  }
}
f("w", "y", "k", "o", "p");

手动滚动迭代器

您仍然可以手动调用返回的迭代器对象的 next() 方法以实现对迭代过程的最大控制。

js
function f() {
  const argsIter = arguments[Symbol.iterator]();
  console.log(argsIter.next().value); // w
  console.log(argsIter.next().value); // y
  console.log(argsIter.next().value); // k
  console.log(argsIter.next().value); // o
  console.log(argsIter.next().value); // p
}
f("w", "y", "k", "o", "p");

规范

规范
ECMAScript 语言规范
# sec-createunmappedargumentsobject
ECMAScript 语言规范
# sec-createmappedargumentsobject

浏览器兼容性

BCD 表格仅在浏览器中加载

另请参阅