作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在 ES6 中,是否可以克隆迭代器状态?
var ma=[1,2,3,4];
var it=ma[Symbol.iterator]();
it.next();
如果我想在这里记住它说明我应该如何在 javascritp 中做?
里面记了什么?自从
JSON.stringify(it) //it would just return {}
最佳答案
您不能克隆任意迭代器,但可以通过保持某个状态从一个迭代器创建许多不同的迭代器:
function tee(iterable) {
const source = iterable[Symbol.iterator]();
const buffers = [[], []]; // substitute in queue type for efficiency
const DONE = Object.create(null);
const next = i => {
if (buffers[i].length !== 0) {
return buffers[i].shift();
}
const x = source.next();
if (x.done) {
return DONE;
}
buffers[1 - i].push(x.value);
return x.value;
};
return buffers.map(function* (_, i) {
for (;;) {
const x = next(i);
if (x === DONE) {
break;
}
yield x;
}
});
}
用法:
const [a, b] = tee(iterator);
assert(a.next().value === b.next().value);
关于javascript - 如何在 javascript 中克隆迭代器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46416266/
我是一名优秀的程序员,十分优秀!