久久久久无码精品,四川省少妇一级毛片,老老熟妇xxxxhd,人妻无码少妇一区二区

jQuery學(xué)習(xí)筆記之jQuery的分析

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

關(guān)于jQuery學(xué)習(xí)筆記之jQuery的分析

  deep是布爾值,表示是否進(jìn)行深度合并,默認(rèn)是false,不執(zhí)行深度合并.

關(guān)于jQuery學(xué)習(xí)筆記之jQuery的分析

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

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

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

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

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

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

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

  因?yàn)閰?shù)的個數(shù)是不確定的,所以沒有列出可接受的具體參數(shù).

  options:指向某個源對象.

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

  src:目標(biāo)對象的某個屬性的原始值.

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

  copyIsArray:指示copy是否是數(shù)組

  clone:深度復(fù)制時原始值的修正值.

  target:目標(biāo)對象.

  i:源對象的起始下標(biāo).

  length:參數(shù)的個數(shù),用于修正變量target.

  deep:是否執(zhí)行深度復(fù)制.

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

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

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

  然后再后面修正.

  341~343:如果目標(biāo)對象target不是對象,不是函數(shù),則targeted={};

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

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

  351行開始循環(huán),i表示開始源對象的下標(biāo),是一個非常巧妙的用法.

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

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

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

  var obj={};

  obj.n1=obj;

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

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

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

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

  

【jQuery學(xué)習(xí)筆記之jQuery的分析】相關(guān)文章:

jQuery的DOM操作筆記07-29

jQuery 源碼分析和Ready函數(shù)06-28

jQuery程序設(shè)計(jì)08-05

jquery提交按鈕的代碼07-28

淺析jQuery 遍歷函數(shù)javascript08-06

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

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

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

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

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