ᆼᆺᆼ*_*ᆼᆺᆼ 6 javascript observable async-await ecmascript-2016
可以在一个async发电机以某种方式广播或组播,使得它的所有迭代器(“消费者”?用户?)收到的所有值?
考虑这个例子:
const fetchMock = () => "Example. Imagine real fetch";
async function* gen() {
for (let i = 1; i <= 6; i++) {
const res = await fetchMock();
yield res.slice(0, 2) + i;
}
}
const ait = gen();
(async() => {
// first "consumer"
for await (const e of ait) console.log('e', e);
})();
(async() => {
// second...
for await (const é of ait) console.log('é', é);
})();Run Code Online (Sandbox Code Playgroud)
迭代“消耗”一个值,所以只有一个或另一个得到它。yield如果可以以某种方式创建这样的生成器,我希望它们(以及任何以后的)都能获得每个ed 值。(类似于Observable.)
这并不容易实现。您需要明确地开球。这与同步迭代器的情况类似,只是稍微复杂一些:
const AsyncIteratorProto = Object.getPrototypeOf(Object.getPrototypeOf(async function*(){}.prototype));
function teeAsync(iterable) {
const iterator = iterable[Symbol.asyncIterator]();
const buffers = [[], []];
function makeIterator(buffer, i) {
return Object.assign(Object.create(AsyncIteratorProto), {
next() {
if (!buffer) return Promise.resolve({done: true, value: undefined});
if (buffer.length) return buffer.shift();
const res = iterator.next();
if (buffers[i^1]) buffers[i^1].push(res);
return res;
},
async return() {
if (buffer) {
buffer = buffers[i] = null;
if (!buffers[i^1]) await iterator.return();
}
return {done: true, value: undefined};
},
});
}
return buffers.map(makeIterator);
}
Run Code Online (Sandbox Code Playgroud)
您应该确保两个迭代器以大致相同的速率消耗,以便缓冲区不会变得太大。
| 归档时间: |
|
| 查看次数: |
137 次 |
| 最近记录: |