这就是我想要做的。
@Component({
selector: "data",
template: "<h1>{{ getData() }}</h1>"
})
export class DataComponent{
this.http.get(path).subscribe({
res => return res;
})
}
如果getData
在内部调用DataComponent
,您可能建议将其分配给变量like this.data = res
并使用i like
{{data}}
。但是我{{getData}}
出于个人目的需要使用like 。请提出建议?
您只是不能直接返回该值,因为它是一个异步调用。异步调用意味着它在后台运行(实际上已计划在以后执行),同时代码继续执行。
您也不能直接在类中有这样的代码。需要将其移至方法或构造函数中。
您可以做的不是subscribe()
直接使用而是使用像map()
export class DataComponent{
someMethod() {
return this.http.get(path).map(res => {
return res.json();
});
}
}
此外,您可以将多个对象.map
与相同的Observables 结合使用,因为有时这可以提高代码的清晰度,并使事情分开。例:
validateResponse = (response) => validate(response);
parseJson = (json) => JSON.parse(json);
fetchUnits() {
return this.http.get(requestUrl).map(this.validateResponse).map(this.parseJson);
}
这样,观察者将返回,呼叫者可以订阅
export class DataComponent{
someMethod() {
return this.http.get(path).map(res => {
return res.json();
});
}
otherMethod() {
this.someMethod().subscribe(data => this.data = data);
}
}
呼叫者也可以在另一个班级。这里只是为了简洁。
data => this.data = data
和
res => return res.json()
是箭头功能。它们类似于正常功能。当数据从响应到达时,这些函数将传递到可观察对象subscribe(...)
或map(...)
从可观察对象调用。这就是为什么不能直接返回数据的原因,因为someMethod()
完成后还没有收到数据。
我正在调用一个函数,其中有一个订户函数。此函数必须返回一个数组,但它给出了一个错误: 缺少订阅。 如何做到这一点?
我知道如何用EventEmitter引发事件。如果我有一个这样的组件,我还可以附加一个要调用的方法: 当我有这样一个组件时,一切都很好。我将一些逻辑移到了服务中,我需要从服务内部引发一个事件。我做的是这样的: 我有一个组件需要根据此事件更新一些值,但我似乎无法使其工作。我尝试的是这样的: 当引发事件的服务不是组件时,如何使MyComponent订阅该事件? 我在 2.0.0-alpha.28 上
我不知道如何从Observable中提取值,由Observable所在的函数返回。我只需要从中返回一个值,其他什么都不需要。 最新版本有效吗 我需要它工作,函数返回值,然后: 我做错了什么?
问题内容: 我需要兑现承诺,以便可以通过封闭函数将其返回。我知道,由于正常的JavaScript范围,我可能无法按照编码的方式进行操作。有什么办法可以做到吗? 位于#1 的 console.log 会生成正确的数据。 console.log #2总是产生’a’; 任何指针将不胜感激。 问题答案: 许诺背后的基本原则之一是它是异步处理的。这意味着您无法创建承诺,然后立即在代码中同步使用其结果(例如,
我使用SockJS和StompJS,当我在浏览器中打开我的应用程序时,有时它会在连接到websocket之前尝试订阅一些主题。我希望主题订阅等待应用程序连接到websocket。 这就是我实现此代码的原因,我将其称为: 因此,我只在连接状态为时才订阅该主题,并且只有在客户端首次成功连接时才会调用该主题。 我想稍后从主题中取消订阅,所以我需要内部订阅返回的对象,我还需要内部订阅的消息。 我所实现的很
mysql会员订阅数据表的设计应该如何设计?产品有订阅商品和非订阅的,每次都只能购买一个。 订阅有1个月 3个月的 每次到期自动扣费。如果在一个月类购买了几个订阅商品 则扣费按照最新的一个 然后延长到期时间。其实是不是每次订阅都不需要生成新订单的 翻阅了其他资料都找不到很好的设计