discuz和jQuery变量名冲突的2种解决方法

这篇文章源码侠主要介绍了的discuz和jQuery变量名冲突的2种解决方法,在开发模板或者插件时经常遇到这个问题,本文列出的3种方法都可以解决这个问题,需要的朋友可以参考下。

缘起于之前自己初次接触开发,做了一款插件,本地测试安装使用的时候发现所有的下拉菜单都不能够使用,鼠标点击没有任何反应,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>

希望源码侠这篇文章能对你有所帮助。

最后送上福利:

1、本站发布的内容若侵犯到您的权益,请邮件联系 84455010@qq.com 删除,我们将及时处理
2、本站大部分下载资源收集于网络,不保证其完整性以及安全性,请下载后自行测试。
3、本站资源仅供学习和交流使用,版权归资源原作者所有,请在下载后24小时之内自觉删除。
4、若作商业用途,请购买正版,由于未及时购买和付费发生的侵权行为,与本站无关。
5、如果你也有好源码或者教程,可以到会员中心投稿发布,分享有积分奖励和额外收入!
6、如果遇到加密压缩包,默认解压密码为“yuanmaxia.com”,如遇到无法解压请联系我们。
源码侠 » discuz和jQuery变量名冲突的2种解决方法

发表评论