为什么ES2015中的字符串可以迭代?

Jus*_*eig 3 javascript iterable ecmascript-6

有人可以帮助我更好地理解在ES2015中使JavaScript字符串可迭代的设计决策吗?大多数iterables代表其他的东西集合:Array,Set,Map,Generator(有点八九不离十).字符串只能是字符串的集合(即,Unicode代码点).因此,如果您希望函数接受字符串集合(例如Set字符串或生成字符串的生成器)单个字符串,则无法区分用户的意图.她是指单个字符串还是可迭代的代码点?与传递字符串集相比,迭代字符似乎是一个角落案例.在这种情况下,我的倾向是当(预期)类型为string∪ 时的特殊情况字符串参数Iterable<string>.

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

我错过了什么?

小智 9

这实际上是ES2015/ES6之前的原则的延续.自从Internet Explorer 8发布以来,每个浏览器都允许您使用相同的语法循环遍历Arrays和Strings的内容.

var array = ['a', 'b', 'c'];

for (var i = 0; i < array.length; i++) {
  console.log(array[i]);
}
Run Code Online (Sandbox Code Playgroud)
var string = 'abc';

for (var i = 0; i < string.length; i++) {
  console.log(string[i]);
}
Run Code Online (Sandbox Code Playgroud)

字符串已经"像阵列一样"; 它们实现了隐式数组迭代协议(具有.length索引属性),并且在查找时每个字符都被视为自己的字符串.我们可以争论这是否是正确的选择,但在这一点上它是遥远的历史.如果在ES2015之后,您需要使用不同的语法来迭代Arrays和Strings,那将是一种奇怪的行为差异.