属性 'unsubscribe' 在类型 'Observable<DataSnapshot>' 上不存在
Property 'unsubscribe' does not exist on type 'Observable<DataSnapshot>'
Typescript(原子编辑器中的 tslint)给我一个 typescript 错误,但我不知道如何设置正确的类型。
错误信息:
聊天组件:
private _chatObserver: Observable<firebase.database.DataSnapshot>
otherMethod () {
this._chatObserver = this._chat.observe(alarmId)
this._chatObserver.subscribe(
(messageSnap: firebase.database.DataSnapshot) => {
this.messages.push(messageSnap.val())
},
error => {throw error})
}
ionViewDidLeave() {
this._chatObserver.unsubscribe()
}
_聊天提供商:
public observe (alarmId){
let messagesRef = this._ref.child(`alarms/${alarmId}/messages`)
const observable = Observable.create(observer => {
messagesRef.on('child_added',(messageSnap) => {
observer.next(messageSnap)
},
(error) => observer.error(error)
)
return () => {
messagesRef.off('value')
};
});
return observable
}
试试这个
private _chatObserver: Observable<firebase.database.DataSnapshot>
private _subscription:Subscription
otherMethod () {
this._chatObserver = this._chat.observe(alarmId)
this._subscription=this._chatObserver.subscribe(
(messageSnap: firebase.database.DataSnapshot) => {
this.messages.push(messageSnap.val())
},
error => {throw error})
}
ionViewDidLeave() {
this._subscription.unsubscribe()
}
Unsubscribe
是订阅本身的一种方法。因此,在顶部添加:
private _chatSubscription;
然后在你的 otherMethod
:
this._chatSubscription = this._chatObserver.subscribe(...);
并且在您的 destroy/leave/termination 处理程序中:
this._chatSubscription.unsubscribe();
Typescript(原子编辑器中的 tslint)给我一个 typescript 错误,但我不知道如何设置正确的类型。
错误信息:
聊天组件:
private _chatObserver: Observable<firebase.database.DataSnapshot>
otherMethod () {
this._chatObserver = this._chat.observe(alarmId)
this._chatObserver.subscribe(
(messageSnap: firebase.database.DataSnapshot) => {
this.messages.push(messageSnap.val())
},
error => {throw error})
}
ionViewDidLeave() {
this._chatObserver.unsubscribe()
}
_聊天提供商:
public observe (alarmId){
let messagesRef = this._ref.child(`alarms/${alarmId}/messages`)
const observable = Observable.create(observer => {
messagesRef.on('child_added',(messageSnap) => {
observer.next(messageSnap)
},
(error) => observer.error(error)
)
return () => {
messagesRef.off('value')
};
});
return observable
}
试试这个
private _chatObserver: Observable<firebase.database.DataSnapshot>
private _subscription:Subscription
otherMethod () {
this._chatObserver = this._chat.observe(alarmId)
this._subscription=this._chatObserver.subscribe(
(messageSnap: firebase.database.DataSnapshot) => {
this.messages.push(messageSnap.val())
},
error => {throw error})
}
ionViewDidLeave() {
this._subscription.unsubscribe()
}
Unsubscribe
是订阅本身的一种方法。因此,在顶部添加:
private _chatSubscription;
然后在你的 otherMethod
:
this._chatSubscription = this._chatObserver.subscribe(...);
并且在您的 destroy/leave/termination 处理程序中:
this._chatSubscription.unsubscribe();