找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 2285|回复: 0

[分享] Discuz!自制模板带jquery时与discuz本身冲突解决办法

[复制链接]
发表于 2017-11-15 09:21:12 | 显示全部楼层 |阅读模式 来自 中国–河南–新乡
由于JQuery的效果很好,在制作模板时难免会用到各种jquery效果。可是做过模板的人就会发现加上自己的juery代码后,discuz自带的一些下拉功能就不可以使用了,其实原因就是discuz和JQuery的$发生冲突,导致有些功能失效。在网上找了一些资料整理了一下,希望能够帮到大家,同时也希望discuz能尽快解决这个问题。

方法一:

在页面的最头部,也就是<head>标签下的第一行开始引入我们用到的JQuery文件,这是为了能确保该JS可以在DZ默认JS之前加载。
在引用到该JS文件的地方把$改成 jQuery(注意大小写)。
如上方式,一般都能解决大部分的JS不兼容情况。如果还是米哟解决的话尝试一下方法:

将用到的JS里面的所有$全部替换成jQuery。

方法二:

DZ使用了$()作为对象选取函数,刚好与jQuery默认的$()函数重合造成冲突,同样也是为了保持原有的DZ程序不被更改,所以我们要在JQ上修改了。不需要修改jquery.js这个文件。只要在引用的时候修改一下即可。
  1. <script src="style/js/jquery.js" type="text/javascript"></script>  
复制代码

这是引用一个jquery核心文件,然后在其下面加上:
  1. <script type="text/javascript">var myJQ = jQuery.noConflict();</script>
复制代码



然后把我们使用的js文件里面的所有$都换成我们自定义的这个值myJQ,大小写要相同。
建议使用第二种方法,如果要用到多个版本的JQ文件的话,就是在每个下面加上这句就好了。如:
  1. <script src="style/js/jquery.1.4.2.js" type="text/javascript"></script>  
  2.   
  3. <script type="text/javascript">var old_JQ = jQuery.noConflict();</script>  
  4.   
  5. <script src="style/js/jquery.1.7.2.js" type="text/javascript"></script>  
  6.   
  7. <script type="text/javascript">var new_JQ = jQuery.noConflict();</script>  
复制代码


发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;

如何回报帮助你解决问题的坛友,好办法就是点击帖子下方的评分按钮给对方加【金币】不会扣除自己的积分,做一个热心并受欢迎的人!

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则 需要先绑定手机号

关闭

站长推荐上一条 /1 下一条

QQ|侵权投诉|广告报价|手机版|小黑屋|西部数码代理|飘仙建站论坛 ( 豫ICP备2022021143号-1 )

GMT+8, 2024-11-23 02:04 , Processed in 0.036738 second(s), 8 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表