詳解Angular中的Observable(可觀察對象)
這篇文章帶大家了解一下Angular 可觀察物件(Observable)。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有幫助。
相關教學推薦:《angular教學》
可觀察物件(Observable)
可觀察物件支援在應用程式的發布者和訂閱者之間傳遞訊息。
可觀察物件是聲明式的 —— 即定義的用於發佈值的函數,在有消費者訂閱它之前,這個函數不會實際執行。
可觀察物件可能會發出的三種通知:
#通知類型 | ##說明|
---|---|
必要。用來處理每個送達值。在開始執行後可能執行零次或多次。 | |
可選。用來處理錯誤通知。錯誤會中斷這個可觀察物件實例的執行過程。 | |
可選。用來處理執行完畢(complete)通知。執行完畢後,這些值就會繼續傳給下一個處理器。 |
定義觀察者
觀察者(observer): 用於接收可觀察物件通知的處理器要實作Observer 接口,這個物件定義了一些回呼函數來處理可觀察物件可能會發出的三種通知。 觀察者物件可以定義這三種處理器的任意組合。如果你不為某種通知類型提供處理器,這個觀察者就會忽略對應類型的通知。
// Create observer object const myObserver = { next: (_data) => { // next通知类型处理器 }, error: err => { // error通知类型处理器 }, complete: () => console.log('Observer got a complete notification'), };
訂閱
只有當Observable的實例被訂閱時,Observable實例才會發佈值。訂閱時要先呼叫該實例的subscribe() 方法,並把一個觀察者物件傳給它,用來接收通知。
語法:Observable.subscribe(ObserverObject),其中,Observable為可觀察物件實例,ObserverObject為觀察者物件。
// 官网示例 // Create simple observable that emits three values const myObservable = of(1, 2, 3); // Create observer object const myObserver = { next: x => console.log('Observer got a next value: ' + x), error: err => console.error('Observer got an error: ' + err), complete: () => console.log('Observer got a complete notification'), }; // Execute with the observer object myObservable.subscribe(myObserver); // Logs: // Observer got a next value: 1 // Observer got a next value: 2 // Observer got a next value: 3 // Observer got a complete notification
myObservable.subscribe( x => console.log('Observer got a next value: ' + x), err => console.error('Observer got an error: ' + err), () => console.log('Observer got a complete notification') );
subscribe() 呼叫會傳回一個註: 無論哪種情況,next通知類型的處理器是必要的,而error和complete處理器是可選的。
Subscription 物件,該物件具有一個 unsubscribe()方法。當呼叫該方法時,你就會停止接收通知。
程式設計影片! !
以上是詳解Angular中的Observable(可觀察對象)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

這篇文章繼續Angular的學習,帶大家了解Angular中的元數據和裝飾器,簡單了解一下他們的用法,希望對大家有幫助!

Angular.js是一種可自由存取的JavaScript平台,用於建立動態應用程式。它允許您透過擴展HTML的語法作為模板語言,以快速、清晰地表示應用程式的各個方面。 Angular.js提供了一系列工具,可協助您編寫、更新和測試程式碼。此外,它還提供了許多功能,如路由和表單管理。本指南將討論在Ubuntu24上安裝Angular的方法。首先,您需要安裝Node.js。 Node.js是一個基於ChromeV8引擎的JavaScript運行環境,可讓您在伺服器端執行JavaScript程式碼。要在Ub

隨著網路的快速發展,前端開發技術也不斷改進與迭代。 PHP和Angular是兩種廣泛應用於前端開發的技術。 PHP是一種伺服器端腳本語言,可以處理表單、產生動態頁面和管理存取權限等任務。而Angular是一種JavaScript的框架,可以用來開發單一頁面應用程式和建構元件化的網頁應用程式。本篇文章將介紹如何使用PHP和Angular進行前端開發,以及如何將它們

這篇文章跟大家分享一個Angular實戰,了解一下angualr 結合 ng-zorro 如何快速開發一個後台系統,希望對大家有幫助!

angular中怎麼使用monaco-editor?以下這篇文章記錄下最近的一次業務中用到的 monaco-editor 在 angular 中的使用,希望對大家有幫助!

這篇文章帶大家了解Angular中的獨立元件,看看怎麼在Angular中建立一個獨立元件,怎麼在獨立元件中導入已有的模組,希望對大家有幫助!
