成人精品一区二区三区中文字幕-成人精品一区二区三区-成人精品一级毛片-成人精品亚洲-日本在线视频一区二区-日本在线视频免费

導航首頁 ? 技術教程 ? jQuery多個版本和其他js庫沖突的解決方法
全站頭部文字 我要出現在這里
jQuery多個版本和其他js庫沖突的解決方法 624 2024-02-22   

jQuery多個版本或和其他js庫沖突主要是常用的$符號的問題,這個問題 jquery早早就有給我們預留處理方法了,下面一起來看看解決辦法。

1.同一頁面jQuery多個版本或沖突解決方法。

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8" />
<title>jQuery測試頁</title>
</head>
<body>
< 引入1.6.4版的jq -->
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.6.4/jquery.js"></script>
<script> var jq164 = jQuery.noConflict(true); </script>
< 引入1.4.2版的jq -->
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.js"></script>
<script> var jq142 = jQuery.noConflict(true); </script>
<script>
(function($){
//此時的$是jQuery-1.6.4
$('#');
})(jq164);
</script>
<script>
jq142(function($){
//此時的$是jQuery-1.4.2
$('#');
});
</script>
</body>
</html>

2.同一頁面jQuery和其他js庫沖突解決方法

jQuery noConflict() 方法

noConflict() 方法會釋放會 $ 標識符的控制,這樣其他腳本就可以使用它了。

jquery.js在prototype.js之前進行引入,如:

<script src="http://www.gimoo.net/t/1901/jquery.js" type="text/javascript"></script>
<script src="http://www.gimoo.net/t/1901/prototype.js" type="text/javascript"></script>
<p id="pp">test---prototype</p>
<p>test---jQuery</p> 

2.1 當然,您仍然可以通過全名替代簡寫的方式來使用 jQuery:

<script type="text/javascript">
jQuery.noConflict(); //將變量$的控制權讓渡給prototype.js,全名可以不調用。
jQuery(function(){ //使用jQuery
jQuery("p").click(function(){
alert( jQuery(this).text() );
});
});
//此處不可以再寫成$,此時的$代表prototype.js中定義的$符號。
$("pp").style.display = 'none'; //使用prototype
</script> 

2.2 您也可以創建自己的簡寫。noConflict() 可返回對 jQuery 的引用,您可以把它存入變量,以供稍后使用。請看這個例子:

<script type="text/javascript">
var $j = jQuery.noConflict(); //自定義一個比較短快捷方式
$j(function(){ //使用jQuery
$j("p").click(function(){
alert( $j(this).text() );
});
});
$("pp").style.display = 'none'; //使用prototype
</script> 

2.3 如果你的 jQuery 代碼塊使用 $ 簡寫,并且您不愿意改變這個快捷方式,那么您可以把 $ 符號作為變量傳遞給 ready 方法。這樣就可以在函數內使用 $ 符號了 - 而在函數外,依舊不得不使用 "jQuery":

<script type="text/javascript">
jQuery.noConflict(); //將變量$的控制權讓渡給prototype.js
jQuery(document).ready(function($){
$("p").click(function(){ //繼續使用 $ 方法
alert( $(this).text() );
});
});
jQuery(function($){ //使用jQuery
$("p").click(function(){ //繼續使用 $ 方法
alert( $(this).text() );
});
});
</script> 

2.4 使用語句塊:

<script type="text/javascript">
jQuery.noConflict(); //將變量$的控制權讓渡給prototype.js
(function($){ //定義匿名函數并設置形參為$
$(function(){ //匿名函數內部的$均為jQuery
$("p").click(function(){ //繼續使用 $ 方法
alert($(this).text());
});
});
})(jQuery); //執行匿名函數且傳遞實參jQuery
$("pp").style.display = 'none'; //使用prototype
</script> 

這種使用語句塊的方法非常有用,在我們自己寫jquery插件時,應該都使用這種寫法,因為我們不知道具體工作過程中是如何順序引入各種js庫的,而這種語句塊的寫法卻能屏蔽沖突。

注意:

1.引用javascript類庫時,把jQuery引用放在最后面,可以避免沖突。

2.特別要注意jQuery()代替$()時,jQuery是區分大小寫的,因為javascript本身就是區分大小寫的。

以上所述是小編給大家介紹的jQuery多個版本和其他js庫沖突的解決方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對綠夏網網站的支持!



主站蜘蛛池模板: 《推拿》完整版播放| 天堂在线电影| 五谷丰登图片| 都市频道节目表今天| 黄色网址在线播放| 在线理论视频| lilywei| 西野翔电影| 如果云知道歌词| 快乐读书吧1-6年级推荐书目| 理发店3| 南男北女| cctv17节目表今天| 抗日电影免费| 电视剧狂飙演员名单| 欺辱尤娜| 红白黑黄| 成年黄色在线观看| 伺机偏宠短剧免费观看| 嗯啊不要啊啊| 廊桥遗梦中被剪掉的一段| 误判电影什么时候上映| 秀人网 官网门户免费| 密使所有演员表| 上门女婿电影完整版免费| 大学英语精读4课后答案| 想想办法吧爸爸| 人口高质量发展形势与政策论文 | 超薄轻舞玉女女裤广场舞| 舅舅的孩子怎么称呼| 大尺度激情吻戏| 女攻男受调教道具| 《西游降魔篇》2| 抖音网页| 生物选择性必修三| 包公大战潘金莲| 我的幸运猫 电视剧| 公民的基本权利和义务教学设计| 王燕玲| 挨饿游戏| 中医把脉|

!!!站長長期在線接!!!

網站、小程序:定制開發/二次開發/仿制開發等

各種疑難雜癥解決/定制接口/定制采集等

站長微信:lxwl520520

站長QQ:1737366103