zoukankan      html  css  js  c++  java
  • 黄聪:Discuz自制模板带jquery时与discuz本身冲突解决办法

    由于JQuery的效果很好,在制作模板时难免会用到各种jquery效果。可是做过模板的人就会发现加上自己的juery代码后,discuz自带的一些下拉功能就不可以使用了,其实原因就是discuz和JQuery的$发生冲突,导致有些功能失效。在网上找了一些资料整理了一下,希望能够帮到大家,同时也希望discuz能尽快解决这个问题。

    方法一:

    1. 在页面的最头部,也就是<head>标签下的第一行开始引入我们用到的JQuery文件,这是为了能确保该JS可以在DZ默认JS之前加载。
    2. 在引用到该JS文件的地方把$改成 jQuery(注意大小写)。

    如上方式,一般都能解决大部分的JS不兼容情况。如果还是米哟解决的话尝试一下方法:

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

    方法二:

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

    <script src="style/js/jquery.js" type="text/javascript"></script>

    这是引用一个jquery核心文件,然后在其下面加上:

    <script type="text/javascript">var CMSZS_JQ = jQuery.noConflict();</script>

    红色字体CMSZS_JQ自定义的,主要就是要注意大小写。

    然后把我们使用的js文件里面的所有$都换成我们自定义的这个值CMSZS_JQ,大小写要相同。

    建议使用第二种方法,如果要用到多个版本的JQ文件的话,就是在每个下面加上这句就好了。如:

    <script src="style/js/jquery.1.4.2.js" type="text/javascript"></script>
    
    <script type="text/javascript">var CMSZS_JQ = jQuery.noConflict();</script>
    
    <script src="style/js/jquery.1.7.2.js" type="text/javascript"></script>
    
    <script type="text/javascript">var CMS_JQ = jQuery.noConflict();</script>

    注意:只要两个自定义的值不相同,各自使用的js语句里面把$改成相应的值就OK了。

  • 相关阅读:
    debug
    whlie and for
    while and for 2
    用鸿蒙开发AI应用(七)触摸屏控制LED
    animation动画组件在鸿蒙中的应用&鸿蒙的定时函数和js的动画效果
    2020技术征文大赛获奖名单公示
    HarmonyOS三方件开发指南(8)——RoundedImage
    从微信小程序到鸿蒙js开发【02】——数据绑定&tabBar&swiper
    从微信小程序到鸿蒙js开发【01】——环境搭建&flex布局
    HarmonyOS三方件开发指南(7)——compress组件
  • 原文地址:https://www.cnblogs.com/huangcong/p/4304286.html
Copyright © 2011-2022 走看看