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 设计模式 观察者

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