WEB开发网      婵犵數濞€濞佳囧磹婵犳艾鐤炬い鎰堕檮閸嬬喐銇勯弽銊с€掗梻鍕閺岋箑螣娓氼垱笑闂佽姘﹂褔婀佸┑鐘诧工妤犲憡绂嶉崜褏纾奸弶鍫涘妼缁楁岸鏌熷畡鐗堝殗闁诡喒鏅犲畷褰掝敃閵堝棙顔忔繝鐢靛仦閸ㄥ爼骞愰幘顔肩;闁规崘绉ぐ鎺撳亹闁绘垶锕╁Λ鍕⒑閹肩偛濡奸悗娑掓櫇缁顓兼径妯绘櫇闂佹寧绻傞弻濠囨晝閸屾稓鍘甸柣搴㈢⊕閿氶柣蹇ョ稻缁绘繃绻濋崘銊т紝闂佽鍨伴崯鏉戠暦閻旂⒈鏁傞柛鈾€鏅欑槐妯衡攽閻愬樊鍤熷┑顔藉劤铻為柛鏇ㄥ墯閸欏繘鏌嶉崫鍕櫣缂佲偓婢跺绠鹃柟瀛樼箘閿涘秵顨ラ悙顏勭伈闁诡喖缍婂畷鎯邦槻婵℃彃顭烽弻娑㈠Ω閵夈儺鍔夌紓浣稿€哥粔褰掑极閹剧粯鏅搁柨鐕傛嫹 ---闂傚倷鐒︾€笛兠洪埡鍛闁跨噦鎷�
开发学院网页设计JavaScript Javascript设计模式:观察者模式 阅读

Javascript设计模式:观察者模式

 2010-09-14 13:10:55 来源:WEB开发网 闂傚倷绶氬ḿ褍螞閹绢喖绠柨鐕傛嫹闂傚倷绀侀幉锟犲垂閻㈠灚宕查柟鎵閸庡秵銇勯幒鎴濃偓鐢稿磻閹炬枼妲堟繛鍡楃С濞岊亞绱撻崒姘扁枌闁瑰嚖鎷�婵犵數濮幏鍐川椤撴繄鎹曢梻渚€娼уú銈吤洪妸鈺佺劦妞ゆ帊鑳堕埊鏇㈡煏閸モ晛浠х紒杈╁仱閺佹捇鏁撻敓锟�闂傚倷绶氬ḿ褍螞閹绢喖绠柨鐕傛嫹  闂傚倷鑳舵灙缂佺粯顨呴埢宥夊即閵忕姵鐎梺缁樺姈椤愮厧鈽夊Ο閿嬬€婚梺褰掑亰閸撴稑鈻斿鑸碘拺闁告稑饪村▓鏃€绻涚仦鍌氬闁崇粯鎹囬獮瀣攽閹邦剚顔傛俊鐐€栧濠氬储瑜忛幉鎾晸閿燂拷
核心提示: 当需求告诉我们,每个对象的内容需要显示不同的时候,Javascript设计模式:观察者模式(3),我们就要把抽象方法按不同的需求重写一次,这个时候JS显示如下:程序代码/*** Get Element by ID* @param {Object} id* @return Element*/

当需求告诉我们,每个对象的内容需要显示不同的时候,我们就要把抽象方法按不同的需求重写一次,这个时候JS显示如下:

程序代码


/**
* Get Element by ID
* @param {Object} id
* @return Element
*/
function $(id){
  return document.getElementById(id);
}
/**
* Window onload function
*/
window.onload = function(){
  var formObj = $("form1");
  formObj["changes"].onclick = function(){
    ChangeContentA($("Box_A"),formObj["fillbox"].value);
    ChangeContentB($("Box_B"),formObj["fillbox"].value);
    ChangeContentC($("Box_C"),formObj["fillbox"].value);
  }
}
/**
*
* @param {Object} elem
* @param {Object} value
*/
function ChangeContentA(elem, value){
  elem.innerHTML = elem.id + ": "+ value;
}
/**
*
* @param {Object} elem
* @param {Object} value
*/
function ChangeContentB(elem, value){
  elem.innerHTML = elem.id + ": "+ value + "[我是Box B]";
}
/**
*
* @param {Object} elem
* @param {Object} value
*/
function ChangeContentC(elem, value){
  elem.innerHTML = value;
}

大家可以发现我们在点击按钮的时候每次都需要去知道这3个对象是否存在,同时按照不同的对象调用不同的方法,因为实例非常简单,可以看到这些对象都在一起,而在实际开发中,这种可能性就很小了,而且很有可能这些对象都是动态创建的,那么我们不可能事先就知道这个对象是否存在,而每次都要去判断对象是否存在就觉得很麻烦,那么观察者模式在这里就可以派上用场了,首先我们先了解一下这个模式的说明:

上一页  1 2 3 4 5 6  下一页

Tags:Javascript 设计模式 观察者

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接