深入分析dwr中的DWRUtil.$

  from:http://blog.csdn.net/pwlazy/archive/2006/06/29/847713.aspx

为了更好的使用dwr的util.js,了解 $是必须的

/**
 * Find the element in the current HTML document with the given id or ids
 * @see http://getahead.ltd.uk/dwr/browser/util/$
 */
var $;

//如果浏览器支持document.getElementById那么进入下面的if块
//IE和firefox都是支持的
if (!$ && document.getElementById) {
 //将$定义为一个函数
  $ = function() {
    //定义一个数组
    var elements = new Array();
    //遍历$函数传入的参数
    for (var i = 0; i < arguments.length; i++) {
      var element = arguments[i];
       //如果参数类型为string,那么通过document.getElementById(element);得到一个对象否折无需转化
      if (typeof element == 'string') {
        element = document.getElementById(element);
      }
      
      //如果参数只有一个那么直接返回参数或者document.getElementById(element);函数结束
    
      if (arguments.length == 1) {
        return element;
      }
       //否则将参数对象或经过转化的对象放入数组
      elements.push(element);
    }
    //参数为多个,则返回数组
    return elements;
  }
}
//倘若浏览器不支持document.getElementById,那么判断是否支持document.all的用法,如果支持则进入下面////的代码段,代码段里面的内容和上面的if段雷同,就不再赘述了
//IE支持document.all,但在firefox下不好用
else if (!$ && document.all) {
  $ = function() {
    var elements = new Array();
    for (var i = 0; i < arguments.length; i++) {
      var element = arguments[i];
      if (typeof element == 'string') {
        element = document.all[element];
      }
      if (arguments.length == 1) {
        return element;
      }
      elements.push(element);
    }
    return elements;
  }
}

 总结
1) 作者通过使用$函数使代码能跨浏览器支持,也就是说你甚至可以使用$(id)或者$(name)的方式获取对象
    (如果浏览器不支持document.getElementById而只支持document.getElementById,使用$(name)是合适的),作者在源代码也都是这样使用的
2)作者在源代码中大量使用$(x),如果x为string(通常是个id),那么返回该id代表的对象,否则直接返回该对象
3) 注意在页面中必须谨慎使用$,不要使用$作为变量 ,很有可能回覆盖前面的函数定义,到时候可能会有奇怪的现象发生

 

你可能感兴趣的:(.net,浏览器,IE,DWR,firefox)