您好,欢迎来到菜鸟吧源码网-本站资源仅供学习与参考,禁止用于商业或违法行为!
  • 首 页
  • 下载APP
  • 公告:菜鸟吧APP于2024.9.15正式上线,请首页右上角进入下载,本站资源均来源于互联网及会员投稿发布,所有资源仅供学习参考研究使用,请勿商用或其它非法用途,商用请购买正版,否则产生一切后果由用户自行承担!谢谢!

     

    当前位置:主页 > 站长学堂 > discuz教程 >
    Discuz和jQuery变量名冲突的3种解决方法
    时间:2019-10-19 13:31 作者:菜鸟哥 浏览:收藏 挑错 打印

    这篇文章主要介绍了Discuz和jQuery变量名冲突的3种解决方法,在开发模板或者插件时经常遇到这个问题,本文列出的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>

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


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

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

    郑重声明:
    本站所有内容均由互联网收集整理、网友上传,并且以计算机技术研究交流为目的,仅供大家参考、学习,不存在任何商业目的与商业用途。 若您需要商业运营或用于其他商业活动,请您购买正版授权并合法使用。
    我们不承担任何技术及版权问题,且不对任何资源负法律责任。
    如无法下载,联系站长索要。
    如有侵犯您的版权,请给我们来信:cainiaovip8@qq.com,我们尽快处理。

    Discuz应用中心安装插件提示“数据下载错误(105)”的解决办法Discuz应用中心安装插件提示“数据下载
    DISCUZ论坛添加页头及页尾背景图片的几种方法DISCUZ论坛添加页头及页尾背景图片的几
    Discuz! X3.4论坛标题字数突破80的限制解决方法Discuz! X3.4论坛标题字数突破80的限制