获得了这个伪代码,用于一个刮取服务,该服务首先探索分页urls,然后是刮过的“父”网站上的子页url。
const pagination = [["url-1", "url-2", "url-3", "url-4"], ["url-5"]];
const timeInterval = 2;
sendRequestsInIntervals(pagination, timeInterval )
.pipe()
.subscribe({
next(x) {
console.log(x);
},
error(err) {
console.error(err);
},
complete() {
console.log("done");
sendRequestsInIntervals(resDataArray, timeInterval ).subscribe({
next(x) {
console.log(x);
},
});
},
});我想避免嵌套,因为这是一种不正确的使用可观察的方法。
有没有办法把它转换成这样的东西:
sendRequestsInIntervals(pagination, timeInterval )
.pipe(
waitUntilCompletes()
mergeMap((resDataArray) => {
return sendRequestsInIntervals(resDataArray, timeInterval );
})
)
.subscribe({
next(x) {
console.log(x);
},
error(err) {
console.error(err);
},
complete() {
console.log("done");
},
});添加了一个名为waitUntilCompletes()的伪函数
在rxJS中是否存在这样一种情况,即在运行之前等待mergeMap中的可观测性,直到之前的可观测性完成为止?
发布于 2021-11-11 15:58:25
last操作符将忽略所有排放,直到完成最后一项:
sendRequestsInIntervals(pagination, timeInterval )
.pipe(
last(),
mergeMap((resDataArray) => { // resDataArray is only the final emitted value from sendRequestsInIntervals()
return sendRequestsInIntervals(resDataArray, timeInterval );
})
)
.subscribe({
next(x) {
console.log(x);
},
error(err) {
console.error(err);
},
complete() {
console.log("done");
},
});或者,您可以使用reduce收集排放并在完成后排放:
sendRequestsInIntervals(pagination, timeInterval )
.pipe(
// this will gather all outter emissions into an array and emit once outter completes
reduce((acc, val) => acc.concat(val), []),
mergeMap((resDataArray) => { // resDataArray is all values emitted from sendRequestsInIntervals() in an array
return sendRequestsInIntervals(resDataArray, timeInterval );
})
)
.subscribe({
next(x) {
console.log(x);
},
error(err) {
console.error(err);
},
complete() {
console.log("done");
},
});https://stackoverflow.com/questions/69931212
复制相似问题