首页 > 语言 > JavaScript > 正文

jQuery多个版本和其他js库冲突的解决方法

2024-05-06 14:53:12
字体:
来源:转载
供稿:网友

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="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(){ //使用jQueryjQuery("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.jsjQuery(document).ready(function($){$("p").click(function(){ //继续使用 $ 方法alert( $(this).text() );});});jQuery(function($){ //使用jQuery$("p").click(function(){ //继续使用 $ 方法alert( $(this).text() );});});</script>             
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选