97国产精品视频人人做人人爱,3344在线观看无码,成年人国产视频,欧美日一级片,在线看AV天堂,高清无码一本到东京热,欧美一级黄片一区2区,免费又爽又刺激高潮网址

jquery原理的簡單分析

2018-5-31    周周

       jquery是一個輕量級的JS框架,這點相信大部分人都聽過,而jquery之所以有這樣一個稱呼,就是因為它悄悄披了一件外衣,將自己給隱藏了起來。

      /以下截取自jquery源碼片段
      (function( window, undefined ) {
      /*    源碼內容    */
       })( window );

      上面這一小段代碼來自于1.9.0當中jquery的源碼,它是一個無污染的JS插件的標準寫法,專業名詞叫閉包。可以把它簡單的看做是一個函數,與普通函數不同的是,這個函數沒有名字,而且會立即執行,就像下面這樣,會直接彈出字符串。

      (function( window, undefined ) {
         alert("Hello World!");
       })( window );

       可以看出來這樣寫的直接效果,就相當于我們直接彈出一個字符串。但是不同的是,我們將里面的變量變成了局域變量,這不僅可以提高運行速度,更重要的是我們在引用jquery的JS文件時,不會因為jquery當中的變量太多,而與其它的JS框架的變量命名產生沖突。對于這一點,我們拿以下這一小段代碼來說明。

     var temp = "Hello World!";
        (function( window, undefined ) {
         var temp = "ByeBye World!";
        })( window );
        alert(temp);

       這段代碼的運行結果是Hello而不是ByeBye,也就是說閉包中的變量聲明沒有污染到外面的全局變量,倘若我們去掉閉包,則最終的結果會是ByeBye,就像下面這樣。

      var temp = "Hello World!";
        //    (function( window, undefined ) {
         var temp = "ByeBye World!";
      //    })( window );
       alert(temp);

       由此就可以看出來,jquery的外衣就是這一層閉包,它是很重要的一個內容,是編寫JS框架必須知道的知識,它可以幫助我們隱藏我們的臨時變量,降低污染。

       剛才我們說了,jquery將自己聲明的變量全部都用外衣遮蓋起來了,而我們平時使用的Jquery和$,卻是真真實實的全局變量,這個是從何而來,謎底就在jquery的某一行代碼,一般是在文件的末尾。

window.jQuery = window.$ = jQuery;
       這一句話將我們在閉包當中定義的jQuery對象導出為全局變量jQuery和$,因此我們才可以在外部直接使用jQuery和$。window是默認的JS上下文環境,因此將對象綁定到window上面,就相當于變成了傳統意義上的全局變量,就像下面這一小段代碼的效果一樣。

      var temp = "Hello World!";
      (function( window, undefined ) {
         var temp = "ByeBye World!";
         window.temp = temp;
       })( window );
       alert(temp);

       很明顯,它的結果應該是ByeBye,而不是Hello。因為我們在閉包中導出了temp局部變量為全局變量,從而覆蓋了第一行聲明的全局變量temp。

        jquery最核心的功能,就是選擇器。而選擇器簡單理解的話,其實就是在DOM文檔中,尋找一個DOM對象的工具。

        首先我們進入jquery源碼中,可以很容易的找到jquery對象的聲明,看過以后會發現,原來我們的jquery對象就是init對象。

         jQuery = function( selector, context ) {
          return new jQuery.fn.init( selector, context, rootjQuery );
         }

         jQuery.fn = jQuery.prototype;

         jQuery.fn.init.prototype = jQuery.fn;
        這兩句話,第一句把jQuery對象的原型賦給了fn屬性,第二句把jQuery對象的原型又賦給了init對象的原型。也就是說,init對象和jQuery具有相同的原型,因此我們在上面返回的init對象,就與jQuery對象有一樣的屬性和方法。
很多時候,我們在jQuery和DOM對象之間切換時需要用到[0]這個屬性。從截圖也可以看出,jQuery對象其實主要就是把原生的DOM對象存在了[0]的位置,并給它加了一系列簡便的方法。這個索引0的屬性我們可以從一小段代碼簡單的看一下它的由來,下面是init方法中的一小段對DOMElement對象作為選擇器的源碼。

      // Handle $(DOMElement)
       if ( selector.nodeType ) {
            /*     可以看到,這里將DOM對象賦給了jQuery對象的[0]這個位置  */
            this.context = this[0] = selector;
            this.length = 1;
           return this;
        }

       這一小段代碼可以在jquery源碼中找到,它是處理傳入的選擇參數是一個DOM對象的情況。可以看到,里面很明顯的將jQuery對象索引0的位置以及context屬性,都賦予了DOM對象。代碼不僅說明了這一點,也同時說明了,我們使用$(DOMElement)可以將一個DOM對象轉換為jQuery對象,從而通過轉換獲得jQuery對象的簡便方法。

日歷

鏈接

個人資料

藍藍設計的小編 http://www.0391cbd.com

存檔

主站蜘蛛池模板: 动漫精品啪啪一区二区三区| 国产尤物视频在线| 国产精品福利社| 亚洲人成人伊人成综合网无码| 亚洲综合极品香蕉久久网| 亚洲清纯自偷自拍另类专区| 免费一看一级毛片| 久久免费视频6| 国产大片黄在线观看| 成人亚洲国产| 国产微拍一区二区三区四区| 欧美国产三级| 久青草国产高清在线视频| 在线精品亚洲一区二区古装| 国产99在线观看| 99性视频| 欧洲一区二区三区无码| 亚洲男人的天堂久久香蕉| 亚洲无码四虎黄色网站| 高清精品美女在线播放| 少妇露出福利视频| 中文无码日韩精品| 欧美在线一二区| 亚洲资源在线视频| 国产高潮流白浆视频| 亚洲第一黄色网址| www.av男人.com| www.99精品视频在线播放| 久久这里只有精品66| 伊人久久综在合线亚洲91| 天堂av综合网| a网站在线观看| 亚洲自拍另类| 99福利视频导航| 亚洲香蕉在线| 亚洲人成影院在线观看| 国产欧美网站| 亚洲国产清纯| 97超爽成人免费视频在线播放| 在线欧美国产| 国内精品伊人久久久久7777人 | 天堂成人在线视频| 美女无遮挡拍拍拍免费视频| 欧洲精品视频在线观看| 欧美激情,国产精品| 69国产精品视频免费| 人妻无码AⅤ中文字| 国产精品色婷婷在线观看| 国产亚洲精品在天天在线麻豆| 成年人久久黄色网站| аⅴ资源中文在线天堂| 国产香蕉在线视频| 午夜国产不卡在线观看视频| 一本无码在线观看| 91免费国产在线观看尤物| 国产91成人| 在线观看国产黄色| 99视频国产精品| 免费观看欧美性一级| 浮力影院国产第一页| 欧美成人一级| 亚洲国产系列| 99热最新网址| 亚洲AⅤ无码日韩AV无码网站| 99精品免费欧美成人小视频| 日韩精品成人网页视频在线 | 国产无套粉嫩白浆| 国产毛片片精品天天看视频| 欧美亚洲另类在线观看| 在线无码九区| 亚洲人成人无码www| 欧美色图第一页| 欧美a网站| 操美女免费网站| 女人18毛片水真多国产| 最新国产精品第1页| 国产成人一二三| 黄色网在线| 欧美va亚洲va香蕉在线| 91最新精品视频发布页| 99热免费在线| 国产高清在线丝袜精品一区|