亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

通過jQuery源碼學(xué)習(xí)javascript(一)

 更新時(shí)間:2012年12月27日 15:44:55   作者:  
最近在做日志統(tǒng)計(jì)程序,發(fā)現(xiàn)對(duì)方的程序是在Jquery基礎(chǔ)上進(jìn)行開發(fā)的,而公司的網(wǎng)站的框架是prototype。而且我也早就想了解一下Jquery源碼,故決定研究Jquery源碼,模擬它的方法
Jquery這么普及,必有它過人之處,通過開源代碼進(jìn)行學(xué)習(xí),是個(gè)不錯(cuò)的學(xué)習(xí)方法?。?

以下是我模擬的方法,我盡量簡(jiǎn)化方法。

定義對(duì)象C(類似于jquery的$方法)——這個(gè)也是jquery設(shè)計(jì)非常巧妙的地方

復(fù)制代碼 代碼如下:

(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注冊(cè)到window屬性中,當(dāng)成全局變量使用。用C做為簡(jiǎn)易名稱。

window.C = window.cQuery = cQuery;

2、
cQuery.fn.init.prototype = cQuery.fn;
  拿圖說話(打印當(dāng)前對(duì)象cQuery):

去掉該句截圖?! ?

填上此句截圖:

難點(diǎn)分析:原型傳遞
  init的原型只是當(dāng)前的函數(shù)?!?

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

each方法
復(fù)制代碼 代碼如下:

(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é)果

難點(diǎn)分析:callback.call(obj[name], name, obj[name])
callback是function(name, type){ console.log(this, name,type);}這個(gè)方法
第一個(gè)obj[name]是"height“或"width"字符串,是callback函數(shù)里的this。
name,第二個(gè)obj[name]是傳給callback的參數(shù)。

isWindow()方法

在上面代碼的基礎(chǔ)上,進(jìn)行編寫:
復(fù)制代碼 代碼如下:

isWindow : function(obj) {
return obj != null && obj == obj.window;
}

調(diào)用:
復(fù)制代碼 代碼如下:

console.log(cquery.isWindow(window));
console.log(cquery.isWindow(document));

輸出結(jié)果

window對(duì)象有一個(gè)特殊的屬性window,等價(jià)于 self 屬性,它包含了對(duì)窗口自身的引用。通過這個(gè)屬性判斷是否是window對(duì)象!

總結(jié)

  我也是剛開始研究??赡苡行┑胤秸f的不是很清楚,如果有人能給我補(bǔ)充,那再好不過了。
  時(shí)間不早了,下回再接著研究。

相關(guān)文章

  • JQuery 學(xué)習(xí)技巧總結(jié)

    JQuery 學(xué)習(xí)技巧總結(jié)

    jQuery是繼prototype之后的又一個(gè)優(yōu)秀的Javascript框架。它是由 John Resig 于 2006 年初創(chuàng)建的,它有助于簡(jiǎn)化 JavaScript™ 以及Ajax 編程。
    2010-05-05
  • jquery中的on方法使用介紹

    jquery中的on方法使用介紹

    使用jquery的朋友對(duì)其中的on方法并不陌生吧,下面為大家介紹下此方法的具體使用,感興趣的朋友可以參考下
    2013-12-12
  • Jquery實(shí)現(xiàn)自定義彈窗示例

    Jquery實(shí)現(xiàn)自定義彈窗示例

    使用javascript自帶的提示對(duì)話框,不怎么美觀,如果使用自定義的,那么在樣式上就會(huì)有更多的控制權(quán)了,下面為大家分享下Jquery自定義的彈窗
    2014-03-03
  • jQuery+PHP實(shí)現(xiàn)上傳裁剪圖片

    jQuery+PHP實(shí)現(xiàn)上傳裁剪圖片

    這篇文章主要為大家詳細(xì)介紹了jQuery+PHP實(shí)現(xiàn)上傳裁剪圖片,以及圖片的預(yù)覽,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-10-10
  • jquery——九宮格大轉(zhuǎn)盤抽獎(jiǎng)實(shí)例

    jquery——九宮格大轉(zhuǎn)盤抽獎(jiǎng)實(shí)例

    本篇文章主要介紹了jquery——九宮格大轉(zhuǎn)盤抽獎(jiǎng)實(shí)例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-01-01
  • jQuery簡(jiǎn)單動(dòng)畫變換效果實(shí)例分析

    jQuery簡(jiǎn)單動(dòng)畫變換效果實(shí)例分析

    這篇文章主要介紹了jQuery簡(jiǎn)單動(dòng)畫變換效果,結(jié)合實(shí)例形式分析了jQuery使用toggle及animate等方法動(dòng)態(tài)操作頁面元素樣式的相關(guān)技巧,需要的朋友可以參考下
    2016-07-07
  • jQuery.Validate驗(yàn)證庫的使用介紹

    jQuery.Validate驗(yàn)證庫的使用介紹

    本篇文章介紹了,jQuery.Validate驗(yàn)證庫的使用。需要的朋友參考下
    2013-04-04
  • 使用jQuery制作遮罩層彈出效果的極簡(jiǎn)實(shí)例分享

    使用jQuery制作遮罩層彈出效果的極簡(jiǎn)實(shí)例分享

    這篇文章主要介紹了使用jQuery制作遮罩層彈出效果的極簡(jiǎn)實(shí)例分享,效果中背景為半透冥且不可操作,在制作頁面上傳功能等場(chǎng)景下十分實(shí)用,需要的朋友可以參考下
    2016-05-05
  • jQuery實(shí)現(xiàn)最簡(jiǎn)單的切換圖效果【可兼容IE6、火狐、谷歌、opera等】

    jQuery實(shí)現(xiàn)最簡(jiǎn)單的切換圖效果【可兼容IE6、火狐、谷歌、opera等】

    這篇文章主要介紹了jQuery實(shí)現(xiàn)最簡(jiǎn)單的切換圖效果,可兼容IE6、火狐、谷歌、opera等瀏覽器,涉及jQuery結(jié)合時(shí)間函數(shù)動(dòng)態(tài)操作頁面元素的相關(guān)技巧,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下
    2016-09-09
  • jQuery?基礎(chǔ)選擇器與屬性選擇器

    jQuery?基礎(chǔ)選擇器與屬性選擇器

    這篇文章主要介紹了jQuery?基礎(chǔ)選擇器與屬性選擇器,選擇所有元素,此選擇器使用要慎重,其速度是極其慢的,詳細(xì)介紹內(nèi)容需要的小伙伴可以參考一下下面文章內(nèi)容
    2022-08-08

最新評(píng)論