• 售前

  • 售后

热门帖子
入门百科

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

[复制链接]
123456809 显示全部楼层 发表于 2021-8-14 15:12:36 |阅读模式 打印 上一主题 下一主题
缘起于之前本身初次打仗开发,做了一款插件,本地测试安装使用的时候发现所有的下拉菜单都不能够使用,鼠标点击没有任何反应,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冲突题目。
第三种,W3C在线手册解决方法,和上面的差不多一样:
http://www.w3school.com.cn/jquery/core_noconflict.asp

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作