欢迎光临
我们一直在努力

Discuz和jQuery变量名冲突的3种解决方法

建站超值云服务器,限时71元/月

缘起于之前自己初次接触开发,做了一款插件,本地测试安装使用的时候发现所有的下拉菜单都不能够使用,鼠标点击没有任何反应,DIY也不能够使用,后来经1314学习网解答说明是DZ和JQ的$冲突!大家平时在写模版或者插件的时候多多少少都会使用JQ,不知道什么时候就会遇到冲突性问题,最近在网上找了很多相关教程,现在与大家进行分享!, ,第一种答案:, ,1、使用到的JS文件无需修改,2、在页面的最头部,也就是标签下的第一行开始引入,这是为了能确保该JS加载在DZ默认JS之前。 3、在引用到该JS文件的地方建$改成 jQuery(注意大小写)。 如上方式,一般都能解决大部分的JS不兼容情况。如果还是米哟解决的话尝试一下方法: 将用到的JS里面的所有$君替换成jQuery。, ,第二种答案:, ,DZ使用了S()作为对象选取函数,刚好与jQuery默认的$()函数重合造成冲突,同样也是为了保持原有的DZ程序不被更改,所以我们要在JQ上修改了。jquery.js 不需要修改这个文件。只要在引用的时候修改一下即可。例如以下代码 是jq 的代码。如果不做修改直接用入DZ会报错。, ,代码如下:, ,

<script type="text/javascript">// <![CDATA[</p> <p>$j(function(){ //使用jQuery 
$("p").click(function(){ 
alert( $(this).text() ); 
}); 
}); </p> <p>$("pp").style.display = 'none'; //使用prototype 
// ]]></script>

, , ,我们可以引用jQuery给JQ赋予一个变量, ,代码如下:, ,

var jq = jQuery.noConflict();</p> <p><script type="text/javascript">// <![CDATA[</p> <p>var jq = jQuery.noConflict(); 
jq(function(){ //使用jQuery 
jq("p").click(function(){ 
alert( jq(this).text() ); 
}); 
}); 
jq("pp").style.display = 'none'; //使用prototype 
// ]]></script>

, , ,替换之后应该是解决js冲突问题。,缘起于之前自己初次接触开发,做了一款插件,本地测试安装使用的时候发现所有的下拉菜单都不能够使用,鼠标点击没有任何反应,DIY也不能够使用,后来经1314学习网解答说明是DZ和JQ的$冲突!大家平时在写模版或者插件的时候多多少少都会使用JQ,不知道什么时候就会遇到冲突性问题,最近在网上找了很多相关教程,现在与大家进行分享!   第一种答案:   1、使用到的JS文件无需修改 2、在页面的最头部,也就是标签下的第一行开始引入,这是为了能确保该JS加载在DZ默认JS之前。 3、在引用到该JS文件的地方建$改成 jQuery(注意大小写)。 如上方式,一般都能解决大部分的JS不兼容情况。如果还是米哟解决的话尝试一下方法: 将用到的JS里面的所有$君替换成jQuery。   第二种答案:   DZ使用了S()作为对象选取函数,刚好与jQuery默认的$()函数重合造成冲突,同样也是为了保持原有的DZ程序不被更改,所以我们要在JQ上修改了。jquery.js 不需要修改这个文件。只要在引用的时候修改一下即可。例如以下代码 是jq 的代码。如果不做修改直接用入DZ会报错。   代码如下:  

<script type="text/javascript">// <![CDATA[</p> <p>$j(function(){ //使用jQuery 
$("p").click(function(){ 
alert( $(this).text() ); 
}); 
}); </p> <p>$("pp").style.display = 'none'; //使用prototype 
// ]]></script>

    我们可以引用jQuery给JQ赋予一个变量   代码如下:  

var jq = jQuery.noConflict();</p> <p><script type="text/javascript">// <![CDATA[</p> <p>var jq = jQuery.noConflict(); 
jq(function(){ //使用jQuery 
jq("p").click(function(){ 
alert( jq(this).text() ); 
}); 
}); 
jq("pp").style.display = 'none'; //使用prototype 
// ]]></script>

    替换之后应该是解决js冲突问题。

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » Discuz和jQuery变量名冲突的3种解决方法
分享到: 更多 (0)