真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

關(guān)于jQuery庫沖突的完美解決辦法

前言

創(chuàng)新互聯(lián)公司2013年開創(chuàng)至今,先為碭山等服務(wù)建站,碭山等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為碭山企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。

一次面試中面試官問到j(luò)Query和別的庫沖突怎么解決?雖然以前看過,但是我已經(jīng)不記得了。

我的思路就是如果讓我來設(shè)計(jì),那我就用一個(gè)默認(rèn)值$,不傳參數(shù),那就用$,最后就掛載在window.$上,傳參數(shù)就用傳入名字,比如傳入jq,那我就掛載在window.jq上。

var myControl="jq";
(function(name){
 var $=name ||"$"; //name存在$的值就是name的值,不存在或?yàn)閚ull,$的值為字符串"$"
 console.log($);
 window[$]=function(){
 alert("123");
 }
})(myControl)
window[myControl]();

事實(shí)上這肯定不是jquery解決沖突的辦法了。那就看看jQuery怎么解決沖突吧。

jQuery多個(gè)版本或和其他js庫沖突主要是常用的$符號(hào)的沖突。

一、沖突的解決

1、同一頁面jQuery多個(gè)版本沖突解決方法










 

 

2、jQuery庫在其他庫之后導(dǎo)入

jQuery noConflict() 方法會(huì)釋放會(huì) $ 標(biāo)識(shí)符的控制,這樣其他腳本就可以使用它了。

1、可以通過jQuery全名替代簡寫的方式來使用 jQuery

在其他庫和jQuery庫都加載完畢后,可以在任何時(shí)候調(diào)用jQuery.noConflict()函數(shù)來將變量$的控制權(quán)移交給其他JavaSript庫。然后就可以在程序里將jQuery()函數(shù)作為jQuery對(duì)象的制造工廠。




test---prototype

test---jQuery

2、自定義一個(gè)快捷方式

noConflict() 可返回對(duì) jQuery 的引用,可以把它存入自定義名稱,例如jq,$J變量,以供稍后使用。

這樣可以確保jQuery不會(huì)與其他庫沖突,同時(shí)又使用自定義一個(gè)快捷方式。

3、在不沖突的情況下仍然用$

如果想在jQuery 代碼塊使用 $ 簡寫,不愿意改變這個(gè)快捷方式,可以把 $ 符號(hào)作為變量傳遞給 ready 方法。這樣就可以在函數(shù)內(nèi)使用 $ 符號(hào)了 , 而在函數(shù)外,依舊不得不使用 "jQuery"。

或者使用IEF語句塊,這應(yīng)該是最理想的方式,因?yàn)榭梢酝ㄟ^改變最少的代碼來實(shí)現(xiàn)全面的兼容性。

在我們自己寫jquery插件時(shí),應(yīng)該都使用這種寫法,因?yàn)槲覀儾恢谰唧w工作過程中是如何順序引入各種js庫的,而這種語句塊的寫法卻能屏蔽沖突。

3、jQuery庫在其他庫之前導(dǎo)入

jQuery庫在其他庫之前導(dǎo)入,$的歸屬權(quán)默認(rèn)歸后面的JavaScript庫所有。那么可以直接使用"jQuery"來做一些jQuery的工作。

同時(shí),可以使用$()方法作為其他庫的快捷方式。這里無須調(diào)用jQuery.noConflict()函數(shù)。







Test-prototype(將被隱藏)

Test-jQuery(將被綁定單擊事件)

二、原理

1、源碼

源碼:看一下源碼里怎么做到的

var
// Map over jQuery in case of overwrite
_jQuery = window.jQuery,

// Map over the $ in case of overwrite
_$ = window.$,

jQuery.extend({
 noConflict: function( deep ) {
   if ( window.$ === jQuery ) {
    window.$ = _$;
   }

   if ( deep && window.jQuery === jQuery ) {
    window.jQuery = _jQuery;
   }

   return jQuery;
  }
});

在jQuery加載的時(shí)候,通過事先聲明的_jQuery變量獲取到當(dāng)前window.jQuery,通過_$獲取到當(dāng)前window.$。

通過jQuery.extend()把noConflict掛載到j(luò)Query下面。所以我們?cè)谡{(diào)用的時(shí)候都是jQuery.noConflict()這樣調(diào)。

在調(diào)用noConflict()時(shí)做了2個(gè)判斷,

第一個(gè)if,把$的控制權(quán)交出去。

第二個(gè)if,在noConflict()傳參的時(shí)候把,jQuery的控制權(quán)交出去。

最后noConflict()返回jQuery對(duì)象,用哪個(gè)參數(shù)接收,哪個(gè)參數(shù)將擁有jQuery的控制權(quán)。

2、 驗(yàn)證

//沖突 
 var $ = 123; //假設(shè)其他庫中$為123
 $(
   function () {
    console.log($); //報(bào)錯(cuò)Uncaught TypeError: $ is not a function
   }
 );

解決沖突

//解決沖突
 var jq = $.noConflict();
 var $ = 123;
 jq(function () {
  alert($); //123
 });

釋放$控制權(quán)例子




aaa

釋放jQuery控制權(quán)例子

參數(shù)deep的作用:deep用來放棄jQuery對(duì)外的接口。

 如下,noConflict()不寫參數(shù),彈出jQuery為構(gòu)造函數(shù)。




aaa

關(guān)于jQuery庫沖突的完美解決辦法

如果寫個(gè)參數(shù)true,會(huì)彈出456。




aaa

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對(duì)創(chuàng)新互聯(lián)的支持。


分享標(biāo)題:關(guān)于jQuery庫沖突的完美解決辦法
網(wǎng)頁路徑:http://weahome.cn/article/ijjddd.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部