通過jQuery源碼學習javascript(一)
更新時間:2012年12月27日 15:44:55 作者:
最近在做日志統(tǒng)計程序,發(fā)現(xiàn)對方的程序是在Jquery基礎上進行開發(fā)的,而公司的網(wǎng)站的框架是prototype。而且我也早就想了解一下Jquery源碼,故決定研究Jquery源碼,模擬它的方法
Jquery這么普及,必有它過人之處,通過開源代碼進行學習,是個不錯的學習方法??!
以下是我模擬的方法,我盡量簡化方法。
定義對象C(類似于jquery的$方法)——這個也是jquery設計非常巧妙的地方
(function(){
var
_cQuery = window.cQuery,
cQuery = function(){
return new cQuery.fn.init();
};
cQuery.fn = cQuery.prototype = {
init : function () {
console.log(this);
return this;
},
test : function () {
console.log('test');
}
};
cQuery.fn.init.prototype = cQuery.fn;
window.C = window.cQuery = cQuery;
})();
C().test();
輸出結(jié)果
1、把cQuery注冊到window屬性中,當成全局變量使用。用C做為簡易名稱。
window.C = window.cQuery = cQuery;
2、
cQuery.fn.init.prototype = cQuery.fn;
拿圖說話(打印當前對象cQuery):
去掉該句截圖?! ?
init的原型只是當前的函數(shù)?!?

用cQuery.fn.init.prototype = cQuery.fn;覆蓋init構造器的原型對象,從而實現(xiàn)跨域訪問。
評估:
這是一招妙棋,new cQuery.fn.init()創(chuàng)建的新對象擁有init構造器的prototype原型對象的方法,通過改變prototype指針的指向,使其指向cQuery類的prototype?!@樣創(chuàng)建出來的對象就繼承了cQuery.fn原型對象定義的方法。
3、用一個var定義變量,函數(shù)。Jquery源碼里用了79行定義了一連串的變量(在開頭部分)。
(function(){
var
_cQuery = window.cQuery,
cQuery = function(){
return new cQuery.fn.init();
};
cQuery.fn = cQuery.prototype = {
init : function () {
return this;
},
each : function(obj, callback) { // each 方法
var name, length = obj.length;
for (name in obj) {
if (callback.call(obj[name], name, obj[name]) === false) {
break;
}
}
},
isWindow : function(obj) {
return obj != null && obj == obj.window;
}
};
cQuery.fn.init.prototype = cQuery.fn;
window.C = window.cQuery =cQuery;
})();
C().each({ Height : 'height', Width : 'width'}, function(name, type){ console.log(this, name, type); });
輸出結(jié)果

難點分析:callback.call(obj[name], name, obj[name])
callback是function(name, type){ console.log(this, name,type);}這個方法
第一個obj[name]是"height“或"width"字符串,是callback函數(shù)里的this。
name,第二個obj[name]是傳給callback的參數(shù)。
isWindow()方法
在上面代碼的基礎上,進行編寫:
isWindow : function(obj) {
return obj != null && obj == obj.window;
}
調(diào)用:
console.log(cquery.isWindow(window));
console.log(cquery.isWindow(document));
輸出結(jié)果
總結(jié)
我也是剛開始研究??赡苡行┑胤秸f的不是很清楚,如果有人能給我補充,那再好不過了。
時間不早了,下回再接著研究。
以下是我模擬的方法,我盡量簡化方法。
定義對象C(類似于jquery的$方法)——這個也是jquery設計非常巧妙的地方
復制代碼 代碼如下:
(function(){
var
_cQuery = window.cQuery,
cQuery = function(){
return new cQuery.fn.init();
};
cQuery.fn = cQuery.prototype = {
init : function () {
console.log(this);
return this;
},
test : function () {
console.log('test');
}
};
cQuery.fn.init.prototype = cQuery.fn;
window.C = window.cQuery = cQuery;
})();
C().test();
輸出結(jié)果

1、把cQuery注冊到window屬性中,當成全局變量使用。用C做為簡易名稱。
window.C = window.cQuery = cQuery;
2、
cQuery.fn.init.prototype = cQuery.fn;
拿圖說話(打印當前對象cQuery):
去掉該句截圖?! ?
填上此句截圖:

init的原型只是當前的函數(shù)?!?

用cQuery.fn.init.prototype = cQuery.fn;覆蓋init構造器的原型對象,從而實現(xiàn)跨域訪問。
評估:
這是一招妙棋,new cQuery.fn.init()創(chuàng)建的新對象擁有init構造器的prototype原型對象的方法,通過改變prototype指針的指向,使其指向cQuery類的prototype?!@樣創(chuàng)建出來的對象就繼承了cQuery.fn原型對象定義的方法。
3、用一個var定義變量,函數(shù)。Jquery源碼里用了79行定義了一連串的變量(在開頭部分)。

復制代碼 代碼如下:
(function(){
var
_cQuery = window.cQuery,
cQuery = function(){
return new cQuery.fn.init();
};
cQuery.fn = cQuery.prototype = {
init : function () {
return this;
},
each : function(obj, callback) { // each 方法
var name, length = obj.length;
for (name in obj) {
if (callback.call(obj[name], name, obj[name]) === false) {
break;
}
}
},
isWindow : function(obj) {
return obj != null && obj == obj.window;
}
};
cQuery.fn.init.prototype = cQuery.fn;
window.C = window.cQuery =cQuery;
})();
C().each({ Height : 'height', Width : 'width'}, function(name, type){ console.log(this, name, type); });
輸出結(jié)果

難點分析:callback.call(obj[name], name, obj[name])
callback是function(name, type){ console.log(this, name,type);}這個方法
第一個obj[name]是"height“或"width"字符串,是callback函數(shù)里的this。
name,第二個obj[name]是傳給callback的參數(shù)。
isWindow()方法
在上面代碼的基礎上,進行編寫:
復制代碼 代碼如下:
isWindow : function(obj) {
return obj != null && obj == obj.window;
}
調(diào)用:
復制代碼 代碼如下:
console.log(cquery.isWindow(window));
console.log(cquery.isWindow(document));
輸出結(jié)果

總結(jié)
我也是剛開始研究??赡苡行┑胤秸f的不是很清楚,如果有人能給我補充,那再好不過了。
時間不早了,下回再接著研究。
您可能感興趣的文章:
相關文章
jQuery基于ajax實現(xiàn)帶動畫效果無刷新柱狀圖投票代碼
這篇文章主要介紹了jQuery基于ajax實現(xiàn)帶動畫效果無刷新柱狀圖投票代碼,通過使用jquery動態(tài)操作頁面元素樣式屬性實現(xiàn)柱狀圖投票效果,非常具有實用價值,需要的朋友可以參考下2015-08-08
Jquery和JS獲取ul中l(wèi)i標簽的實現(xiàn)方法
下面小編就為大家?guī)硪黄狫query和JS獲取ul中l(wèi)i標簽的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-06-06
Javascript函數(shù)中的arguments.callee用法實例分析
這篇文章主要介紹了Javascript函數(shù)中的arguments.callee用法,結(jié)合實例形式分析了arguments.callee操作當前方法引用的具體技巧,需要的朋友可以參考下2016-09-09
jQuery選擇器源碼解讀(七):elementMatcher函數(shù)
這篇文章主要介紹了jQuery選擇器源碼解讀(七):elementMatcher函數(shù),本文講解了源碼、功能、參數(shù)、返回函數(shù) 等內(nèi)容,需要的朋友可以參考下2015-03-03
JQuery實現(xiàn)table行折疊效果以JSON做數(shù)據(jù)源
這篇文章主要介紹JQuery實現(xiàn)的table行折疊效果并以JSON做數(shù)據(jù)源,需要的朋友可以參考下2014-05-05

