欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解jQuery中的getAll()和cleanData()

 更新時間:2019年04月15日 09:47:09   作者:小進進  
這篇文章主要介紹了jQuery之getAll()和cleanData()函數(shù)的實例代碼解析,非常不錯,具有一定的參考借鑒價值,需要的朋友參考下吧

前言:

看 jQuery 源碼的一個痛點就是調(diào)用一個函數(shù)時,里面會調(diào)用 N 個其他函數(shù),然后這 N 個函數(shù)里面又會調(diào)用 M 個其他其他函數(shù)。。

本篇文章主要是對detach()/empty()/remove()/unwrap()]() 中兩個函數(shù) getAll和cleanData() 進行解析。

一、getAll(context, tag)

作用:

用來獲取 context 上的 tag 標簽,或者是將 context 和 context 里的 tag 標簽的元素合并

源碼:

//一般是傳的node,'script'
 //應該是用來獲取context上的tag標簽,或者是將context和context里的tag標簽的元素合并
 //源碼4893行
 function getAll( context, tag ) {
  // Support: IE <=9 - 11 only
  // Use typeof to avoid zero-argument method invocation on host objects (#15151)
  var ret;
  console.log(context,typeof context.getElementsByTagName,typeof context.querySelectorAll,'context4894')
  //如果context存在getElementsByTagName的方法的話
  if ( typeof context.getElementsByTagName !== "undefined" ) {
   //tag:script
   //從context中獲取script標簽的節(jié)點
   ret = context.getElementsByTagName( tag || "*" )
   console.log(tag,ret,'ret4897')
  }
 //DocumentFragment沒有getElementsByTagName方法,但有querySelectorAll方法
 else if ( typeof context.querySelectorAll !== "undefined" ) {
   ret = context.querySelectorAll( tag || "*" );
  } else {
   ret = [];
  }
  console.log(nodeName( context, tag ),'nodeName4909')
  //nodeName() 判斷兩個參數(shù)的nodename是否相等
  if ( tag === undefined || tag && nodeName( context, tag ) ) {

   return jQuery.merge( [ context ], ret );
  }
  return ret;
 }

注意:DocumentFragment 沒有getElementsByTagName方法,但有querySelectorAll方法!

二、$.merge()

作用:

合并兩個數(shù)組內(nèi)容到第一個數(shù)組

源碼:

 // Support: Android <=4.0 only, PhantomJS 1 only
  // push.apply(_, arraylike) throws on ancient WebKit
  //源碼461行
  //將second合并到first后面
  merge: function( first, second ) {
   var len = +second.length,
    j = 0,
    i = first.length;
   //依次將second的item添加到first后面
   for ( ; j < len; j++ ) {
    first[ i++ ] = second[ j ];
   }
   //first可能是類數(shù)組,所以需要更新下length屬性
   first.length = i;
   return first;
  },

需要注意的是最后的 first.length = i

三、cleanData()

作用:

清除元素節(jié)點上的事件和數(shù)據(jù)

源碼:

 //清除elems上的數(shù)據(jù)和事件
  //源碼6146行
  cleanData: function( elems ) {
   var data, elem, type,
    //beforeunload/blur/click/focus/focusin/focusout/
    //load/mouseenter/mouseleave/pointerenter/pointerleave
    special = jQuery.event.special,
    i = 0;
   for ( ; ( elem = elems[ i ] ) !== undefined; i++ ) {
    //允許的節(jié)點類型
    if ( acceptData( elem ) ) {
     //當有事件綁定到elem后,jQuery會給elem一個屬性dataPriv.expando
     //該屬性上面就綁定了事件和數(shù)據(jù)
     if ( ( data = elem[ dataPriv.expando ] ) ) {
      //如果data上有事件的話
      if ( data.events ) {
       //逐個列舉data上的事件,比如click
       for ( type in data.events ) {
        // 如果special中有data.events上的事件
        if ( special[ type ] ) {
         //調(diào)用jQuery.event.remove方法,移除elem上的event類型
         jQuery.event.remove( elem, type );
         // This is a shortcut to avoid jQuery.event.remove's overhead
        }
        //應該是自定義的事件
        else {
         //本質(zhì)即elem.removeEventListener(type,handle)
         jQuery.removeEvent( elem, type, data.handle );
        }
       }
      }
      // Support: Chrome <=35 - 45+
      // Assign undefined instead of using delete, see Data#remove
      //最后將元素的dataPriv.expando屬性置為undefined
      elem[ dataPriv.expando ] = undefined;
     }
     //dataUser應該是用戶綁定的事件
     if ( elem[ dataUser.expando ] ) {
      // 將元素的dataUser.expando屬性置為undefined
      // Support: Chrome <=35 - 45+
      // Assign undefined instead of using delete, see Data#remove
      elem[ dataUser.expando ] = undefined;
     }
    }
   }
  }

解析:

① 依次判斷 elems[i] 是否是元素節(jié)點/文檔節(jié)點/對象

② 再判斷 elem 的 dataPriv.expando 屬性是否有 events 屬性

③ 當 events 里有 jQuery.event.special 指定的 事件類型時,
使用jQuery.event.remove(elem,type)移除事件和數(shù)據(jù)

④ 反之,則使用jQuery.removeEvent(elem,type,data.handle)移除事件和數(shù)據(jù)

⑤ 將 elem[dataPriv.expando]置為 undefined

⑥ 將 elem[dataUser.expando]置為 undefined

四、acceptData()

作用:

判斷是否是指定的節(jié)點類型,返回 true/false

源碼:

 //判斷是否是指定的節(jié)點類型
 //只接受元素節(jié)點1,文檔節(jié)點9,任意對象
 //返回true/false
 //源碼4178行
 var acceptData = function( owner ) {
  // Accepts only:
  // - Node
  //  - Node.ELEMENT_NODE
  //  - Node.DOCUMENT_NODE
  // - Object
  //  - Any
  return owner.nodeType === 1 || owner.nodeType === 9 || !( +owner.nodeType );
 }

注意:

Object 類型的 nodeType 是 undefined

五、$.removeEvent()

作用:

移除 elem 上的自定義監(jiān)聽事件

源碼:

 //移除elem上的自定義監(jiān)聽事件
 //源碼5599行
 //jQuery.removeEvent(elem,type,data.handle)
 jQuery.removeEvent = function( elem, type, handle ) {
  // This "if" is needed for plain objects
  if ( elem.removeEventListener ) {
   elem.removeEventListener( type, handle );
  }
 }

本質(zhì)即調(diào)用原生JS的removeEventListener()方法

總結(jié)

以上所述是小編給大家介紹的jQuery中的getAll()和cleanData(),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

您可能感興趣的文章:

相關文章

  • jQuery和HTML對某個標簽設置只讀或者禁用屬性的方式

    jQuery和HTML對某個標簽設置只讀或者禁用屬性的方式

    這篇文章主要介紹了jQuery和HTML對某個標簽設置只讀或者禁用屬性的方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • jQuery實現(xiàn)按鈕的點擊 全選/反選 單選框/復選框 文本框 表單驗證

    jQuery實現(xiàn)按鈕的點擊 全選/反選 單選框/復選框 文本框 表單驗證

    這篇文章主要介紹了jQuery實現(xiàn)按鈕的點擊 全選/反選 單選框/復選框 文本框 表單驗證的相關資料,需要的朋友可以參考下
    2015-06-06
  • jQuery實現(xiàn)仿騰訊迷你首頁選項卡效果代碼

    jQuery實現(xiàn)仿騰訊迷你首頁選項卡效果代碼

    這篇文章主要介紹了jQuery實現(xiàn)仿騰訊迷你首頁選項卡效果代碼,可實現(xiàn)tab切換按鈕的左右滑動顯示及點擊切換效果,涉及jQuery基于鼠標事件實現(xiàn)頁面元素動態(tài)操作技巧,需要的朋友可以參考下
    2015-09-09
  • jQuery中事件與動畫的總結(jié)分享

    jQuery中事件與動畫的總結(jié)分享

    下面小編就為大家?guī)硪黄猨Query中事件與動畫的總結(jié)分享。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-05-05
  • 淺談struts1 & jquery form 文件異步上傳

    淺談struts1 & jquery form 文件異步上傳

    下面小編就為大家?guī)硪黄獪\談struts1 & jquery form 文件異步上傳。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-05-05
  • jQuery中insertAfter()方法用法實例

    jQuery中insertAfter()方法用法實例

    這篇文章主要介紹了jQuery中insertAfter()方法用法,實例分析了insertAfter()方法的功能、定義及匹配的元素插入到另一個指定的元素集合后面的使用技巧,需要的朋友可以參考下
    2015-01-01
  • jQuery樣式操作方法整理介紹

    jQuery樣式操作方法整理介紹

    這篇文章主要介紹了jQuery樣式操作方法,并通過實際案例更淺顯的理解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2022-10-10
  • jQuery ajax serialize()方法的使用以及常見問題解決

    jQuery ajax serialize()方法的使用以及常見問題解決

    使用ajax時,常常需要拼裝input數(shù)據(jù)為'name=abc&sex=1'這種形式,用JQuery的serialize方法可以輕松的完成這個工作接下來介紹jQuery ajax - serialize() 方法定義和用法,感興趣的朋友可以了解下啊,希望本文對你有所幫助
    2013-01-01
  • jQuery實現(xiàn)驗證碼功能

    jQuery實現(xiàn)驗證碼功能

    本文主要介紹了jQuery實現(xiàn)驗證碼功能的示例代碼,具有很好的參考價值,下面跟著小編一起來看下吧
    2017-03-03
  • Tab頁界面,用jQuery及Ajax技術實現(xiàn)

    Tab頁界面,用jQuery及Ajax技術實現(xiàn)

    從桌面開發(fā)的時代開始,Tab頁就是一個優(yōu)異的界面布局形式,兼有菜單的樣式和充分復用有限的界面的優(yōu)點。
    2009-09-09

最新評論