Mengakses Nilai Semasa Subjek RxJS atau Boleh Diperhatikan
Subjek RxJS dan boleh diperhatikan tidak sememangnya mempunyai nilai semasa. Apabila nilai dipancarkan, ia hanya dihantar kepada pelanggan seketika.
Walau bagaimanapun, dalam senario di mana nilai semasa adalah penting, pertimbangkan untuk menggunakan BehaviorSubject, subjek khusus yang direka untuk tujuan ini. BehaviorSubject mengekalkan nilai terkini yang dikeluarkan, memberikannya serta-merta kepada pelanggan baharu dan menawarkan kaedah getValue() untuk mendapatkan semula nilai semasa.
Contoh:
Dalam perkhidmatan Angular kami , mari gantikan Subject dengan BehaviorSubject:
<code class="typescript">private _isLoggedInSource = new BehaviorSubject<boolean>(false); isLoggedIn = this._isLoggedInSource.asObservable();</code>
Kini, kita boleh mengakses nilai semasa menggunakan getValue():
<code class="typescript">import { SessionStorage } from './session-storage.service'; import { Component, OnInit } from '@angular/core'; @Component({ selector: 'my-component', templateUrl: './my-component.html' }) export class MyComponent implements OnInit { isLoggedIn: boolean; constructor(private sessionStorage: SessionStorage) { } ngOnInit() { this.isLoggedIn = this.sessionStorage.isLoggedIn.getValue(); } }</code>
Atas ialah kandungan terperinci Bagaimana untuk Mengakses Nilai Semasa Subjek RxJS atau Boleh Diperhatikan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!