我的机械网

搜索
查看: 1055|回复: 8

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

[复制链接]

28

主题

-28

回帖

0

积分

小白会员

Rank: 1

积分
0
发表于 2017-12-10 23:17:55 | |阅读模式
各位网友请注意:我的机械网所有附件、百度网盘提取码、机械资料、PDF资料、压缩包文件均需要回帖后才能下载!

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


复制代码
代码如下:



我们可以引用jQuery给JQ赋予一个变量

复制代码
代码如下:

var jq = jQuery.noConflict();



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

第三种,W3C在线手册解决方法,和上面的差不多一样:

http://www.w3school.com.cn/jquery/core_noconflict.asp

发表于 2017-12-12 09:02:55 |
今天是2017-12-12,过来看看庄生梦蝶づ的帖子,涨涨见识!
发表于 2018-1-5 03:51:37 |
革命小卫兵谢谢庄生梦蝶づ提供的资料。
发表于 2018-11-28 10:58:30 |
庄生梦蝶づ

0

主题

5682

回帖

3万

积分

论坛元老

Rank: 8Rank: 8

积分
39294
发表于 2018-12-2 00:22:00 |
kaka
发表于 2021-11-30 16:29:56 |
态度决定一切,不错!
发表于 2021-11-30 16:29:58 |
好东西,赞一个!
发表于 2021-11-30 20:51:59 |
论坛的人气越来越旺了!
发表于 2021-12-1 13:47:48 |
没人理我,好伤心啊!
快速回复 返回顶部 返回列表