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

Javascript
JS getMonth()日期函数的值域是0-11
jQuery 处理网页内容的实现代码
jQuery 树形结构的选择器
jQuery 处理表单元素的代码
JQuery 动画卷页 返回顶部 动画特效(兼容Chrome)
JavaScript 10件让人费解的事情
类似GMAIL的Ajax信息反馈显示
两个比较有用的Javascript工具函数代码
JavaScript Timer实现代码
JavaScript 学习技巧
JavaScript 题型问答有答案参考
js删除select中重复项的实现代码
javascript中的链式调用
JavaScript DOM学习第一章 W3C DOM简介
JavaScript DOM 学习第二章 编辑文本
JavaScript DOM 学习第三章 内容表格
JavaScript DOM学习第四章 getElementByTagNames
JavaScript DOM 学习第五章 表单简介
JavaScript DOM学习第六章 表单实例
JavaScript DOM 学习第七章 表单的扩展

Javascript 中的 JQuery教程:简化JQuery


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2010-01-03   浏览: 143 ::
收藏到网摘: 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}
});
才疏学浅,错误之处,敬请指正。