天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

jQuery與其它庫沖突的解決方法

(注意:默認情況下,jQuery用$作為自身的縮寫而以)
如果jQuery類庫和別的類庫沖突的話,可以使用jQuerynoConflict()函數來將變量$的控制權移交出給其它的JavaScipt庫。看下面小片斷代碼
<script type="text/Javascript" src="../JS/JsCOM.js"></script>
<script type="text/Javascript" src="../jQuery/jquery-1.3.2-vsdoc2.js"></script>
假設JsCOM.js庫中,有這樣一個函數
復制代碼 代碼如下:
function $(objName) {
if (document.getElementById) {
return eval('document.getElementById("' + objName + '")')
}
else {
return eval("document.all." + objName)
}

大家都知道jQuery里面也一個這樣的函數,為了不引起沖突,我們將jQuery的變量$的控制權移交出給別的Javascript庫
復制代碼 代碼如下:
jQuery.noConflict(); //將變量$的控制權移交給JsCOM.js
var $cr = jQuery("#cr"); //照樣使用jQuery類庫,只是用jQuery代替了原來的$而以。
var JsCOM_cr = $("cr"); //使用JsCOM.js類庫

在這里可以把jQuery()函數作為jQuery對象的制造工廠.
在這里要注意幾點
1.引用Javascript類庫時,一定要把jQuery引用放在最后面,就像上面一樣,JsCOM.js的引用在jQuery引用的前面(具體原因我也不知,不過確實需要這樣)
2.特別要注意jQuery()代替$()時,jQuery是區分大小寫的,因為Javascript本身就是區分大小寫的(好像說這個有點多余,不過還是希望大家不要犯這種錯誤)
基本上根據上面的
方法就可以解決jQuery和其它庫的沖突問題了!
如果你覺得上面的方式不爽,每次都要打jQuery來代替$增加了您敲鍵盤的工作量,那請接著看。。
除上面之外,還有另一種選擇。如果想確保jQuery不會與其它庫沖突,但又想自定義一個快捷方式,可以進行如下操作;
復制代碼 代碼如下:
var $j = jQuery.noConflict(); //自定一個快捷方式
var $cr = $j("#cr"); //使用jQuery類庫,得用自定義快捷方式----$j;
var JsCOM_cr = $("cr"); //和上一段代碼一樣,使用的是JsCOM.js類庫

如果您還有別的要求,想繼續使用原先的$(),同時還需要與別的類庫不沖突的話,還有兩種解決方法
其一:
復制代碼 代碼如下:
jQuery.noConflict(); //將變量$的控制權讓給JsCOM.js
jQuery(function($)
{
$("p").click(function() //在函數內繼續可以使用jquery類庫的$()方法
{
alert($(this).text());
})
})
var JsCOM_cr = $("cr"); // 在函數外面,照樣可以使用JsCOM.js的$()方法

其二:
復制代碼 代碼如下:
jQuery.noConflict(); //將變量$的控件權移交給別的類庫,使用jquery類庫的$符號時,請使用jQuery("#id");
(function($) { //定義匿名函數并設置形參為$
$(function() { //匿名函數內部的$均為jQuery
$("div").click(function() {//繼續使用$()方法
alert($(this).text());
})
})
})
(jQuery); //使用匿名函數且傳遞實參jQUery
alert($("cr")); //使用的是jsCOM.js類庫中的$()函數

第二種方法應該是兼容舊的代碼最好的方式,修改的代碼是最少的!
不過如果是新寫的jQuery代碼,我還是比較喜歡使用剛開始講的那種(jQuery.noConflict(),然后就使用jQuery("#id"),這種方式)
如果您的頁面是先引用jQuery類庫再引入別的類庫的話,那么我們可以直接使用jQuery來做一些工作,同時,可以使用$()方法作為其它庫的快捷方式。這里無需調用jQuery.noConflict()函數,請看下面代碼
復制代碼 代碼如下:
<script type="text/Javascript" src="../jQuery/jquery-1.3.2-vsdoc2.js"></script>
<script type="text/Javascript" src="../JS/JsCOM.js"></script>
jQuery().ready(function() { //無需調用jQuery.noConflict()函數
var $cr = jQuery("#cr");
$cr.click(function() {
if ($cr.is(":checked")) {
alert("感謝你的支持!你可以繼續操作了..");
}
})
})
alert($("cr")); //使用的是jsCOM.js類庫中的$()函數

好了,看了上面這么多種方法來解決沖突,這下你可以放心的在您的項目中引用jQuery了吧 :)

JavaScript技術jQuery與其它庫沖突的解決方法,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产欧美一本道无码 | 东京热百度影音 | 一个人在线观看免费中文www | 国产欧美另类久久久精品免费 | 国产精品九九久久精品视 | 高H纯肉NP 弄潮NP男男 | 超碰在线视频人人AV | 欧美一道本一区二区三区 | 最近中文字幕2018MV高清在线 | 被六个男人躁到一夜同性 | 我的美女房东未删减版免费观看 | 久久天天躁狠狠躁夜夜躁 | 成年女人免费影院播放 | 色戒床震视频片段 | 摸董事长的裤裆恋老小说 | 俄罗斯老妇女BBXX | 亚洲精品午夜久久久伊人 | yellow日本动漫免费观看 | 亚洲精品无码专区在线播放 | 任你躁国语自产二区在线播放 | 色狠狠xx| 午夜福利在线观看6080 | 亚洲欧美中文在线一区 | 9位美女厕所撒尿11分 | 让人爽到湿的小黄书 | 好男人在线视频 | 草神被爆漫画羞羞漫画 | 国产小伙和50岁熟女23p | 18女下面流水不遮网站免费 | 女性性纵欲派对 | A级毛片无码久久精品免费 a级毛片黄免费a级毛片 | 十九禁啊啪射视频在线观看 | xxx日本hd| 黑色丝袜美腿美女被躁翻了 | 极品少妇粉嫩小泬啪啪AV | 古代荡乳尤物H妓女调教 | 人与人特黄一级 | 儿媳妇完整版视频播放免费观看 | 国产精品内射久久久久欢欢 | 肉色欧美久久久久久久蜜桃 | 男助理憋尿PLAY灌尿BL出去 |