成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

談?wù)?jQuery 中的防沖突機(jī)制

開發(fā) 前端
jQuery.noConflict 方法包含一個(gè)可選的布爾參數(shù)[1],用以決定移交 $ 引用的同時(shí)是否移交 jQuery 對(duì)象本身。

許多的 JS 框架類庫都選擇使用 $ 符號(hào)作為函數(shù)或變量名,jQuery 是其中最為典型的一個(gè)。在 jQuery 中,$ 符號(hào)只是 window.jQuery 對(duì)象的一個(gè)引用,因此即使 $ 被刪除,window.jQuery 依然是保證整個(gè)類庫完整性的堅(jiān)強(qiáng)后盾。jQuery 的 API 設(shè)計(jì)充分考慮了多框架之間的引用沖突,我們可以使用 jQuery.noConflict 方法來輕松實(shí)現(xiàn)控制權(quán)的移交。

jQuery.noConflict 方法包含一個(gè)可選的布爾參數(shù)[1],用以決定移交 $ 引用的同時(shí)是否移交 jQuery 對(duì)象本身:

  1. jQuery.noConflict([removeAll]) 

缺省情況下,執(zhí)行 noConflict 會(huì)將變量 $ 的控制權(quán)移交給第一個(gè)產(chǎn)生 $ 的庫;當(dāng) removeAll 設(shè)置為 true 時(shí),執(zhí)行 noConflict 則會(huì)將 $ 和 jQuery 對(duì)象本身的控制權(quán)全部移交給第一個(gè)產(chǎn)生他們的庫。

例如在 KISSY 和 jQuery 混用,并且慣用 $ = KISSY 來簡化 API 操作的時(shí)候,就能夠通過這個(gè)方法解決命名沖突的問題。

那么這個(gè)機(jī)制是如何實(shí)現(xiàn)的呢?閱讀 jQuery 源碼開頭[2],首先做的一件事情是這樣的:

  1. // Map over jQuery in case of overwrite  
  2. _jQuery = window.jQuery,  
  3.    
  4. // Map over the $ in case of overwrite  
  5. _$ = window.$, 

容易理解的是,jQuery 通過兩個(gè)私有變量映射了 window 環(huán)境下的 jQuery 和 $ 兩個(gè)對(duì)象,以防止變量被強(qiáng)行覆蓋。一旦 noConflict 方法被調(diào)用,則通過 _jQuery, _$, jQuery, $ 四者之間的差異,來決定控制權(quán)的移交方式,具體的代碼如下:

  1. noConflict: function( deep ) {  
  2.                 if ( window.$ === jQuery ) {  
  3.                         window.$ = _$;  
  4.                 }  
  5.    
  6.                 if ( deep && window.jQuery === jQuery ) {  
  7.                         window.jQuery = _jQuery;  
  8.                 }  
  9.    
  10.                 return jQuery;  
  11.         } 

再來看上面所說的參數(shù)設(shè)定問題,如果 deep 沒有設(shè)置,_$ 覆蓋 window.$,此時(shí) jQuery 別名 $ 失效,但 jQuery 本身完好無損。如果有其他類庫或代碼重新定義了 $ 變量,它的控制權(quán)就完全交接出去了。反之如果 deep 設(shè)置為 true 的話,_jQuery 覆蓋 window.jQuery,此時(shí) $ 和 jQuery 都將失效。

這種操作的好處是,不管是框架混用還是 jQuery 多版本共存這種高度沖突的執(zhí)行環(huán)境,由于 noConflict 方法提供的移交機(jī)制,以及本身返回未被覆蓋的 jQuery 對(duì)象,完全能夠通過變量映射的方式解決沖突。

但無法避免的事實(shí)是可能導(dǎo)致的插件失效等問題,當(dāng)然通過簡單修改上下文參數(shù)即可恢復(fù) $ 別名

  1. var query = jQuery.noConflict(true);  
  2. (function ($) {  
  3.    
  4.      // 插件或其他形式的代碼,也可以將參數(shù)設(shè)為 jQuery  
  5.    
  6. })(query); 

[1] http://api.jquery.com/jQuery.noConflict/#jQuery-noConflict-removeAll

[2] https://github.com/jquery/jquery/blob/master/src/core.js

原文鏈接:http://ued.taobao.com/blog/2013/03/jquery-noconflict/

責(zé)任編輯:張偉 來源: 淘寶UED
相關(guān)推薦

2017-12-06 10:15:27

跳轉(zhuǎn)機(jī)制Chrome

2012-07-09 14:25:04

程序集加載

2010-01-11 10:46:31

2024-02-20 09:50:02

Redis分布式

2022-08-26 00:21:44

IO模型線程

2016-09-26 17:15:51

2012-02-08 10:12:19

Java反射

2012-03-29 09:57:06

jQuery

2011-08-15 09:30:59

SQL Server

2015-08-07 10:24:17

AndroidMaterialDes

2022-06-07 08:31:44

JavaUnsafe

2016-07-15 09:58:00

應(yīng)用交付單邊加速太一星晨

2013-06-19 09:54:37

產(chǎn)品設(shè)計(jì)產(chǎn)品功能推薦功能

2012-05-17 09:28:06

代碼審查Java代碼

2024-08-26 14:52:58

JavaScript循環(huán)機(jī)制

2011-08-11 09:56:50

模式

2023-08-14 16:56:53

2010-04-20 14:18:23

2023-11-23 12:12:00

2010-09-28 11:05:49

jQuery
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 成人精品国产免费网站 | 日韩在线视频免费观看 | 国产二区视频 | 99久久精品国产一区二区三区 | 中文字幕精品一区二区三区精品 | 久久精品亚洲精品国产欧美 | 国产精品美女久久久 | 久草视频在线播放 | 精品亚洲国产成av人片传媒 | 亚洲精品久久久一区二区三区 | 一级片在线播放 | 国产真实乱全部视频 | 欧美日韩综合一区 | 丁香五月网久久综合 | 美国一级片在线观看 | 日本午夜在线视频 | 日韩午夜精品 | 亚洲国产精品成人 | 精品国产乱码久久久久久88av | 国产视频中文字幕在线观看 | 久久久女女女女999久久 | 99精品久久久久久 | 福利视频网站 | 成人精品区 | 亚洲日本乱码在线观看 | 精品久久99 | 国产亚洲精品成人av久久ww | 超碰97人人人人人蜜桃 | 影音av | 偷拍第一页 | 九九精品网| 黄色av网站在线观看 | 日本a视频 | 亚洲一区二区在线免费观看 | av大片| 亚洲天堂中文字幕 | 欧美久久久久 | 久久的色| 精品一二三| 亚洲国产在 | 视频精品一区二区三区 |