Angular2 Rxjs 观察者不会设置如果超过一个

Angular2 Rxjs observers are not setting if more then one

我正在尝试从我的构造函数中设置多个观察者。只有一个正在设置,其余的未设置为空(未更改)。

我不确定为什么要这样做。

export class gq {

    /**
     * This is observable data service https://coryrylan.com/blog/angular-2-observable-data-services
     */
    constructor(private api: Api)
    {
        this._ = {

            // just to define object here, else it will give error
            observer: {
                s: '', q: '', translation: '', translationLanguage: '', transliteration: '', r: '', content: ''
            },

            // observables
            observable: {
                s$:                 new Observable(observer => this._.observer.s = observer).share(),
                q$:                 new Observable(observer => this._.observer.q = observer).share(),
                translation$:           new Observable(observer => this._.observer.translation = observer).share(),
                translationLanguage$:   new Observable(observer => this._.observer.translationLanguage = observer).share(),
                transliteration$:       new Observable(observer => this._.observer.transliteration = observer).share(),
                r$:               new Observable(observer => this._.observer.r = observer).share(),
                content$:               new Observable(observer => this._.observer.content = observer).share(),
            }
        };


        console.log(this._.observer);
        console.log('triggered constructor');
    }
}

输出为

Object {s: Subject, q: "", translation: "", translationLanguage: "", transliteration: ""…}

如您所见,它只设置了 s 和 Subject,但其余的都是 null

我不知道您的应用程序代码的其余部分,但您需要知道可观察对象是惰性的。这意味着您在调用 Observable 构造函数时指定的回调仅在您订阅它时被调用。

也许您只订阅了第一个 observable 而没有订阅其他...