当前位置: 首页 > 图文教程 > 网络编程 > Javascript > JQuery教程:简化JQuery

Javascript
JavaScript DOM学习第八章 表单错误提示
JavaScript DOM 学习第九章 选取范围的介绍
JavaScript CSS修改学习第一章 查找位置
JavaScript CSS修改学习第二章 样式
JavaScript CSS修改学习第三章 修改样式表
JavaScript CSS 修改学习第四章 透明度设置
JavaScript CSS修改学习第五章 给“上传”添加样式
JavaScript CSS修改学习第六章 拖拽
Jquery乱码的一次解决过程 图解教程
javascript 包裹节点 提高效率
javascript inneHTML的地雷
javascript 定义新对象方法
判定对象是否为window的js代码
jquery validator 插件增加日期比较方法
jquery 得到当前页面高度和宽度的两个函数
JavaScript 编写匿名函数的几种方法
jQuery 操作下拉列表框实现代码
jQuery入门问答 整理的几个常见的初学者问题
第一个JavaScript入门基础 document.write输出
javascript入门基础之私有变量

Javascript 中的 JQuery教程:简化JQuery


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2010-01-03   浏览: 73 ::
收藏到网摘: n/a

这是以前整理的一些代码,与JQer分享,希望对大家能有些帮助。

话说功能愈发强大的JQuery体积也不再小巧,55k(Minified)的大小虽然不能说很大,但如果用在一些小型项目或网站上,也不算小,那么我们何不根据自己项目特点,简化或改写JQuery呢,Follow me!

首先是JQuery的核心代码:
代码:
//不完全一致,但实现手段大致如此
(function(){
  window._$ = window.$;
  var $ = window.$ = function(s) {
    return new $.fn.init(s);
  };
  $.fn = $.prototype = {
    init: function(s) {
      if(!s) return this;
      if (s.nodeType) {
        this.e = [];
        this.e.push(s);  //存储获取到的Elements      
        return this;
      }
      if (typeof s == “string”) {
        return $().find(s);
      }
      return this;
    },
    find: function(s) {
      //根据传入的String,查找DOM
    }
  };
  // extend扩展方法
  $.fn.extend = function(p) {
    for(var key in p) {
      if(!$.fn[key]) {
        $.fn[key] = p[key];
      }
    }
  };
  $.fn.init.prototype = $.fn;
})();
$().extend({
  “a”: function(s){},
  “b”: function(s){}
});
再附上我简化的版本
代码:
// by CNwander
(function(){
window._$ = window.$;
var eleExpr =  /([#\.a-zA-Z])([^\s]+)/g;
var $ = window.$ = function(s) {
     return new $.fn.init(s);
};
$.fn = $.prototype = {
  init: function(s) {
   this.e = null;
   if(!s) return this;
   if (s.nodeType) {
    this.e = [];
    this.e.push(s);
    return this;
   }
   if (typeof s == “string”) {
    return $().find(s);
   }
   else
    return this;
  },
  find: function(s) {
   var wrap = this.e || [document];
   var result = [];
   for(var key in wrap) {
    var target = wrap[key];
    while(eleExpr.test(s)) {
     var first = RegExp.$1,
      content = RegExp.$2;
     target = $().clean(target,content,first);
    }
    if(target == null)
     result = null;
    else
     for(var i = 0; i < target.length; i++)
      result.push(target[i]);
   }
   this.e = result;
   return this;   
  },
  clean: function(wrap,content,type){
   if(!wrap) return null;
   wrap = wrap instanceof Array ? wrap : [wrap];
   var result = new Array();
   for(var key in wrap) {
    var temp;
    switch(type) {
    case “#”:
     temp = wrap[key].getElementById(content);
     break;
    case “.”:
     temp = $().getElemsByClassName(content,wrap[key]);
     break;
    default:
     temp = wrap[key].getElementsByTagName(type+content);
    }
    if(temp) {
     temp = temp.length ? temp : [temp];
     for (var i = 0; i < temp.length; i++)
      if(temp[i].nodeType) result.push(temp[i]);
    }
   }
   result = result.length <= 0 ? null : result;
   return result;
  },
  getElemsByClassName: function(classname,elem,tag) {
   tag = tag || “*”;
   elem = elem || document;
   elem = elem instanceof Array ? elem : [elem];
   var result = new Array();
   for(var key in elem) {
    var allElems = elem[key].getElementsByTagName(tag) || elem[key].all;
    var oElem;
    for(var i=0; i<allElems.length; i++){
     oElem = allElems[i];
     var list = oElem.className.split(” “);
     for(var j=0; j<list.length; j++){
      if(list[j] == classname) result.push(oElem);
     }      
    }
   }
   return result.length <= 0 ? null : result;
  }
};
$.fn.extend = function(p) {
  for(var key in p) {
   if(!$.fn[key]) {
    $.fn[key] = p[key];
   }
  }
};
$.fn.init.prototype = $.fn;
})();
$.ajax = function(url,postStr,lastfunc,errfunc) {
var ajax = false;
if(window.XMLHttpRequest) {
  ajax = new XMLHttpRequest();
  if (ajax.overrideMimeType) {
   ajax.overrideMimeType(”text/xml”);
  }
}
else if (window.ActiveXObject) {
  try {
   ajax = new ActiveXObject(”Msxml2.XMLHTTP”);
  }
  catch (e) {
   try {
      ajax = new ActiveXObject(”Microsoft.XMLHTTP”);
    }
   catch (e) {
   }
  }
}
if (!ajax) {
  if(errfunc) errfunc();
  return false;
}
ajax.open(”POST”, url, true);
ajax.setRequestHeader(”Content-Type”,”application/x-www-form-urlencoded”);
ajax.send(postStr);
ajax.onreadystatechange = function() {
  if (ajax.readyState == 4 && ajax.status == 200) {
   if(lastfunc) lastfunc(ajax.responseText);
  }
}  
}
$().extend({
”html”: function(val){
  return val == undefined ?
  (this.e[0] ?
   this.e[0].innerHTML :
   null) :
  this.e[0].innerHTML = val;
},
”empty”: function() {
  for(var i in this.e) {
   var o = this.e[i];
   o.innerHTML = ”;
  }
  return this;
},
”css”: function() {
  if(!this.e || arguments.length <= 0) return this;
  if(arguments.length == 1 && typeof arguments[0] == “string”) {
   arguments[0] = arguments[0].toLowerCase();
   return this.e[0].currentStyle ?
   this.e[0].currentStyle[arguments[0]] :
   window.getComputedStyle (this.e[0], “”).getPropertyValue(arguments[0].replace(/([A-Z])/g, “-$1″));
  }
  else if(arguments.length >= 2) {
   for (var i in this.e)
   this.e[i].style[arguments[0]] = arguments[1];
  }
},
”hasClass”: function(name) {
  if(!this.e) return this;
  var allClass =  this.e[0].className.split(” “);
  for (var key in allClass)
  if(allClass[key] == name) return true;
  return false;
},
”addClass”: function(name){
  if(this.e)
   for (var i in this.e)
    if(this.e[i].nodeType == 1)
     this.e[i].className += ” “+name;
  return this;
},
”removeClass”: function(name){
  if(this.e)
   for (var i in this.e) {
    var temp = [],
     allClass =  this.e[i].className.split(” “);
    for(var j = 0, k = 0; j < allClass.length; j++) {
     if(allClass[j] != name) {
      temp[k++] = allClass[j]
     }
    }
    allClass = temp.join(” “);
    this.e[i].className = allClass;
   }
  return this;
},
”mousedown”: function(callback){
  if(!this.e) return this;
  for(var key in this.e) {
   this.e[key].onmousedown = callback;
   return this;
  }
},
”mouseover”: function(callback){if(!this.e) return this;for(var key in this.e) {this.e[key].onmouseover = callback} return this},
”mouseout”: function(callback){if(!this.e) return this;for(var key in this.e) {this.e[key].onmouseout = callback}return this}
});
才疏学浅,错误之处,敬请指正。