天天看點

解決jQuery多個版本,與其他js庫沖突方法

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

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

<!DOCTYPE html>
<html >
<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="jquery.js" type="text/javascript"></script>
<script src="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本身就是區分大小寫的。