为什么字符串在 ES2015 中是可迭代对象

Why are strings iterables in ES2015?

本文关键字:迭代 对象 字符串 ES2015 为什么      更新时间:2023-09-26

有人可以帮助我更好地理解在ES2015中使JavaScript字符串可迭代的设计决策吗?大多数可迭代对象表示其他事物的集合:ArraySetMapGenerator(有点像)。字符串只能是字符串的集合(好吧,Unicode 代码点)。因此,如果您希望函数接受字符串集合(例如 Set字符串或生成字符串的生成器)单个字符串,无法区分用户的意图。她指的是单个字符串还是代码点的可迭代对象?与传递字符串集合相比,迭代字符似乎是一个极端情况。在这种情况下,我倾向于在(预期)类型为stringIterable<string>时使用特殊情况的字符串参数。

function deleteDocuments(ids /* string or Iterable<string> */) {
  if('string' === typeof ids) { 
    deleteSingleDocById(ids);
  } else {
    for(let id of ids) { 
      deleteSingleDocById(id);
    }
  }
}

我错过了什么?

这实际上是ES2015/ES6之前的原则的延续。自 Internet Explorer 8 发布以来,每个浏览器都允许您使用相同的语法遍历数组和字符串的内容。

var array = ['a', 'b', 'c'];
for (var i = 0; i < array.length; i++) {
  console.log(array[i]);
}
var string = 'abc';
for (var i = 0; i < string.length; i++) {
  console.log(string[i]);
}

字符串已经是"类似数组的";它们满足了隐式数组迭代协议(具有.length和索引属性),并且每个字符在查找时都已被视为自己的字符串。我们可以争论这是否是正确的选择,但在这一点上,这是遥远的历史。如果在 ES2015 之后,您希望使用不同的语法来迭代数组和字符串,那将是一个奇怪的行为分歧。