有人可以帮助我更好地理解在ES2015中使JavaScript字符串可迭代的设计决策吗?大多数迭代表示其他事物的集合: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);
}
}
}
我错过了什么?
答案 0 :(得分: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]);
}
var string = 'abc';
for (var i = 0; i < string.length; i++) {
console.log(string[i]);
}
字符串已经是&#34;类似数组&#34 ;;它们实现了隐式数组迭代协议(具有.length
和索引属性),并且每个字符在查找时都已被视为自己的字符串。我们可以争论这是否是正确的选择,但它在这一点上是遥远的历史。如果在ES2015之后,您需要使用不同的语法来迭代Arrays和Strings,那将是一种奇怪的行为差异。