码迷,mamicode.com
首页 > Web开发 > 详细

JS 模拟Jquery

时间:2015-04-16 23:08:13      阅读:154      评论:0      收藏:0      [点我收藏+]

标签:

<script type=text/javascript charset=utf-8>
// 模拟jquery底层链式编程
// 块级作用域
//特点1 程序启动的时候 里面的代码直接执行了
//alert(‘我执行了‘);
//特点2 内部的成员变量 外部无法去访问 (除了不加var修饰的变量)
//a = 10 ;
(function(window , undefined){
// $ 最常用的对象 返回给外界 大型程序开发 一般使用‘_‘作为私用的对象(规范)
function _$(arguments){
//实现代码...
// 正则表达式匹配id选择器
var idselector = /#\w+/ ;
this.dom ; // 此属性 接受所得到的元素
// 如果匹配成功 则接受dom元素 arguments[0] = ‘#inp‘
if(idselector.test(arguments[0])){
this.dom = document.getElementById(arguments[0].substring(1));
} else {
throw new Error(‘ arguments is error !‘);
}
};

// 在Function类上扩展一个可以实现链式编程的方法
Function.prototype.method = function(methodName , fn){
this.prototype[methodName] = fn ;
return this ; //链式编程的关键
}

// 在_$的原型对象上 加一些公共的方法
_$.prototype = {
constructor : _$ ,
addEvent:function(type,fn){
// 给你的得到的元素 注册事件
if(window.addEventListener){// FF
this.dom.addEventListener(type , fn);
} else if (window.attachEvent){// IE
this.dom.attachEvent(‘on‘+type , fn);
}
return this ;
},
setStyle:function(prop , val){
this.dom.style[prop] = val ;
return this ;
}
};
// window 上先注册一个全局变量 与外界产生关系
window.$ = _$ ;
// 写一个准备的方法
_$.onReady = function(fn){
// 1 实例化出来_$对象 真正的注册到window上
window.$ = function(){
return new _$(arguments);
};
// 2 执行传入进来的代码
fn();
// 3 实现链式编程
_$.method(‘addEvent‘,function(){
// nothing to do
}).method(‘setStyle‘,function(){
// nothing to do
});

};

})(window); // 程序的入口 window传入作用域中

$.onReady(function(){
var inp = $(‘#inp‘);
//alert(inp.dom.nodeName);
//alert($(‘#inp‘));
inp.addEvent(‘click‘,function(){
alert(‘我被点击了!‘);
}).setStyle(‘backgroundColor‘ , ‘red‘);
});

</script>

JS 模拟Jquery

标签:

原文地址:http://www.cnblogs.com/jalja/p/4433421.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!