您好,登錄后才能下訂單哦!
觀察者模式意圖
定義對象間的一種一對多的依賴關系,當一個對象的狀態發生改變時,所有依賴于它的對象都得到通知并被自動更新。
實現過程
在老師教程中學到了 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; });
使用時調用self.notifyObserver
方法。只要是注冊過的觀察者都會得到一個通知。
時序圖
總結
觀察者模式:我覺得用一個詞來總結,就是群發。
當一個對象發生改變的同時,需要其他對象也改變,但是并不知道具體有多少個對象改變。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。