<delect id="sj01t"></delect>
  1. <em id="sj01t"><label id="sj01t"></label></em>
  2. <div id="sj01t"></div>
    1. <em id="sj01t"></em>

            <div id="sj01t"></div>

            jQuery學習筆記之jQuery的分析

            時間:2024-10-27 14:41:19 jQuery Mobile 我要投稿
            • 相關推薦

            關于jQuery學習筆記之jQuery的分析

              deep是布爾值,表示是否進行深度合并,默認是false,不執行深度合并.

            關于jQuery學習筆記之jQuery的分析

              通過這種方式可以在jQuery或jQuery.fn上添加新的屬性和方法,jQuery的其他模塊大都是這么實現的.

              給jQuery添加擴展時用$.extend()

              如:jQuery.extend({add:function(a,b){return a+b}})

              使用:$.add(1,3)=====>4;

              給jQuery實例對象添加擴展時用$.fn.extend();

              $.fn.extend({gys:function(){$(this).css("color","red")}});

              調用:$("div.guo").gys();

              因為參數的個數是不確定的,所以沒有列出可接受的具體參數.

              options:指向某個源對象.

              name:某個源對象的某個屬性名.

              src:目標對象的某個屬性的原始值.

              copy:某個源對象的某個屬性的值

              copyIsArray:指示copy是否是數組

              clone:深度復制時原始值的修正值.

              target:目標對象.

              i:源對象的起始下標.

              length:參數的個數,用于修正變量target.

              deep:是否執行深度復制.

              333~338:如果第一個參數是布爾值,則把target賦值給deep,target在重新獲取值,把第二個參數賦給target.

              這個時候i值從一開始的1變成了2.表示源對象本來是從第二個元素開始的,現在變成了第三個元素了.這段代碼結合

              327行代碼就知道為什么會有這個if語句了.原來函數extend在執行的時候,不管參數情況如何,首先給target和i賦值.

              然后再后面修正.

              341~343:如果目標對象target不是對象,不是函數,則targeted={};

              346~349:length和i相等時,表示沒有傳入objcet1,...之類的參數,

              這個時候把this當前對象(jQuery或jQuery.fn)作為目標對象,在把i減一.從而使傳入的對象當作源對象.

              351行開始循環,i表示開始源對象的下標,是一個非常巧妙的用法.

              353行也很精彩,它把獲取源對象和對源對象的判斷放在了一條語句中,只有源對象不為空時才會執行.

              354~362行,變量src是原始值,變量copy是復制值.如果target和copy引用相同,為了遍歷時死循環,

              因此不會覆蓋目標對象的同名屬性.如果注釋掉360行,下面的代碼會出現異常.

              var obj={};

              obj.n1=obj;

              $.extend(true,obj,{n2:obj});

              在不同瀏覽器中會出項不同的報錯,但是都無一例外的出現卡屏很久的現像.

              365~372行,如果是深度合并,且復制copy是普通javascript對象或數組,則遞歸合并.

              378~380行,如果不是深度合并,并且copy不是undefined,則直接覆蓋目標對象的同名屬性.

              

            【jQuery學習筆記之jQuery的分析】相關文章:

            jQuery的DOM操作筆記07-29

            jQuery 源碼分析和Ready函數06-28

            jQuery程序設計08-05

            jquery提交按鈕的代碼07-28

            淺析jQuery 遍歷函數javascript08-06

            jQuery中prev()方法用法07-16

            jQuery中replaceAll()方法用法10-15

            如何理解jquery事件冒泡09-15

            jquery之超簡單的div顯示和隱藏特效demo簡介05-15

            jQuery中parent()和siblings()的問題10-16

            <delect id="sj01t"></delect>
            1. <em id="sj01t"><label id="sj01t"></label></em>
            2. <div id="sj01t"></div>
              1. <em id="sj01t"></em>

                      <div id="sj01t"></div>
                      黄色视频在线观看