如何解决rxjs 管道到 observable 在将其绑定到 observable 引用时不会引发
谁能解释一下为什么这个打字稿代码有效,并且 - 地图和点击被提升:
var request = this.http.get("https://jsonplaceholder.typicode.com/todos/1")
.pipe(
map(x => {
console.log(map);
//this will be raised
}),tap((x: any) => {
console.log(tap);
//this will be raised
}
));
request.subscribe((x) => alert(x));
在这段代码中:
var request = this.http.get("https://jsonplaceholder.typicode.com/todos/1");
request.pipe(
map(x => {
console.log(map);
//this will not be raised
}),tap((x: any) => {
console.log(tap);
//this will not be raised
}
));
request.subscribe((x) => alert(x));
地图和水龙头没有凸起。 为什么他们的行为不同?
如果这是预期的行为 - 例如,将请求创建和管道分离到不同位置的正确方法是什么 - 一种方法创建请求,第二种方法将其绑定到管道,第三种方法引发它通过调用“订阅”。
谢谢!
解决方法
基本上你需要类似的东西
const request = this.http.get("https://jsonplaceholder.typicode.com/todos/1");
const piped = request.pipe(
map(x => {
console.log(map);
}),tap((x: any) => {
console.log(tap);
}
));
const subscription = piped.subscribe((x) => alert(x));
注意:避免使用 var
,而是使用 const/let
,它们是块作用域的(这是您大多数时候想要的),而 var
不是。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。