本文實例講述了JavaScript編程設計模式之觀察者模式。分享給大家供大家參考,具體如下:
簡介
簡單的解釋觀察者模式,就是一個對象(subject)維護一個依賴他的對象(observers)列表,當自身狀態發生變化時,自動通知所有觀察者對象。當某個對象不需要獲得通知時,可以從對象列表中刪除掉。
從上面的解釋中我們可以提煉出三個componet: Subject, ObserverList和Observer,用JS實現很簡單:
function ObserverList(){ this.observerList = [];}ObserverList.prototype.Add = function( obj ){ return this.observerList.push( obj );};ObserverList.prototype.Empty = function(){ this.observerList = [];};ObserverList.prototype.Count = function(){ return this.observerList.length;};ObserverList.prototype.Get = function( index ){ if( index > -1 && index < this.observerList.length ){ return this.observerList[ index ]; }};ObserverList.prototype.Insert = function( obj, index ){ var pointer = -1; if( index === 0 ){ this.observerList.unshift( obj ); pointer = index; }else if( index === this.observerList.length ){ this.observerList.push( obj ); pointer = index; } return pointer;};ObserverList.prototype.IndexOf = function( obj, startIndex ){ var i = startIndex, pointer = -1; while( i < this.observerList.length ){ if( this.observerList[i] === obj ){ pointer = i; } i++; } return pointer;};ObserverList.prototype.RemoveAt = function( index ){ if( index === 0 ){ this.observerList.shift(); }else if( index === this.observerList.length -1 ){ this.observerList.pop(); }};// Extend an object with an extensionfunction extend( extension, obj ){ for ( var key in extension ){ obj[key] = extension[key]; }}Subject擁有增加和刪除Observer的能力
function Subject(){ this.observers = new ObserverList();}Subject.prototype.AddObserver = function( observer ){ this.observers.Add( observer );};Subject.prototype.RemoveObserver = function( observer ){ this.observers.RemoveAt( this.observers.IndexOf( observer, 0 ) );};Subject.prototype.Notify = function( context ){ var observerCount = this.observers.Count(); for(var i=0; i < observerCount; i++){ this.observers.Get(i).Update( context ); }};最后定義一個觀察者對象,實現update方法
// The Observerfunction Observer(){ this.Update = function(){ // ... };}當有多個觀察者,只需擴展上面的基本對象,并重寫Update方法。
盡管觀察則模式被廣泛使用,但在JS中經常使用它的變體: 發布訂閱模式
發布訂閱模式通過一個topic/event通道,解耦了觀察者模式中Subject(發布者)和Observer(訂閱者)之間耦合的問題,在JS中被廣泛使用。
下面簡單的例子說明了使用發布訂閱模式的基本結構
// A very simple new mail handler// A count of the number of messages receivedvar mailCounter = 0;// Initialize subscribers that will listen out for a topic// with the name "inbox/newMessage".// Render a preview of new messagesvar subscriber1 = subscribe( "inbox/newMessage", function( topic, data ) { // Log the topic for debugging purposes console.log( "A new message was received: ", topic ); // Use the data that was passed from our subject // to display a message preview to the user $( ".messageSender" ).html( data.sender ); $( ".messagePreview" ).html( data.body );});// Here's another subscriber using the same data to perform// a different task.// Update the counter displaying the number of new// messages received via the publishervar subscriber2 = subscribe( "inbox/newMessage", function( topic, data ) { $('.newMessageCounter').html( mailCounter++ );});publish( "inbox/newMessage", [{ sender:"hello@google.com", body: "Hey there! How are you doing today?"}]);// We could then at a later point unsubscribe our subscribers// from receiving any new topic notifications as follows:// unsubscribe( subscriber1, );// unsubscribe( subscriber2 );
新聞熱點
疑難解答
圖片精選