• <nav id="cwumo"><code id="cwumo"></code></nav>
  • <menu id="cwumo"><strong id="cwumo"></strong></menu>

    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

    日韩激情