淺談Angular 觀察者模式理解
更新時間:2018年11月01日 10:16:56 作者:潘佳琦
這篇文章主要介紹了淺談Angular 觀察者模式理解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
觀察者模式意圖
定義對象間的一種一對多的依賴關系,當一個對象的狀態(tài)發(fā)生改變時,所有依賴于它的對象都得到通知并被自動更新。
實現(xiàn)過程
在老師教程中學到了 Angularjs 中的觀察者模式
不使用觀察者模式,登錄時不實時獲取當前登錄用戶,必須刷新界面
使用觀察者模式
代碼
Services:
// 觀察者 self.observerCallbacks = []; // 注冊觀察者 self.reisterObserverCallback = function(callback){ self.observerCallbacks.push(callback); }; // 通知觀察者 self.notifyObserver = function(currentLoginTeacher){ angular.forEach(self.observerCallbacks, function(callback){ callback(currentLoginTeacher); }); };
Controller:
// 注冊觀察者 teacher.reisterObserverCallback(function(teacher){ $scope.data.CurrentLoginTeacher = teacher; });
使用時調(diào)用self.notifyObserver
方法。只要是注冊過的觀察者都會得到一個通知。
時序圖
總結
觀察者模式:我覺得用一個詞來總結,就是群發(fā)。
當一個對象發(fā)生改變的同時,需要其他對象也改變,但是并不知道具體有多少個對象改變。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
AngularJs的UI組件ui-Bootstrap之Tooltip和Popover
這篇文章主要介紹了AngularJs的UI組件ui-Bootstrap之Tooltip和Popover,tooltip和popover是輕量的、可擴展的、用于提示的指令。具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-07-07angular-ngSanitize模塊-$sanitize服務詳解
本篇文章主要介紹了angular-ngSanitize模塊-$sanitize服務詳解 ,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-06-06