• 技术文章 >web前端 >js教程

    关于jQuery库冲突怎么办

    小云云小云云2018-01-11 14:08:40原创789

    在使用jQuery开发的时候,可能还会使用到其他的JS库,比如Prototype,但多库共存时可能会发生冲突,本文主要给大家介绍了关于jQuery库冲突的完美解决办法,需要的朋友可以参考借鉴,下面来一起看看吧。

    我的思路就是如果让我来设计,那我就用一个默认值$,不传参数,那就用$,最后就挂载在window.$上,传参数就用传入名字,比如传入jq,那我就挂载在window.jq上。

    var myControl="jq";
    (function(name){
     var $=name ||"$"; //name存在$的值就是name的值,不存在或为null,$的值为字符串"$"
     console.log($);
     window[$]=function(){
     alert("123");
     }
    })(myControl)
    window[myControl]();

    事实上这肯定不是jquery解决冲突的办法了。那就看看jQuery怎么解决冲突吧。

    jQuery多个版本或和其他js库冲突主要是常用的$符号的冲突。

    一、冲突的解决

    1、同一页面jQuery多个版本冲突解决方法

    <body>
    <!-- 引入1.6.4版的jq -->
    <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.6.4/jquery.js"></script>
    <script> var jq164 = jQuery.noConflict(true); </script>
    <!-- 引入1.4.2版的jq -->
    <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.js"></script>
    <script> var jq142 = jQuery.noConflict(true); </script>
    
    <script>
    (function($){
     //此时的$是jQuery-1.6.4
     $('#');
    })(jq164);
    </script>
     
    <script>
    jq142(function($){
     //此时的$是jQuery-1.4.2
     $('#');
    });
    </script>
     
    </body>

    2、jQuery库在其他库之后导入

    jQuery noConflict() 方法会释放会 $ 标识符的控制,这样其他脚本就可以使用它了。

    1、可以通过jQuery全名替代简写的方式来使用 jQuery

    在其他库和jQuery库都加载完毕后,可以在任何时候调用jQuery.noConflict()函数来将变量$的控制权移交给其他JavaSript库。然后就可以在程序里将jQuery()函数作为jQuery对象的制造工厂。

    <script src="prototype.js" type="text/javascript"></script>
    <script src="jquery.js" type="text/javascript"></script>
    
    <p id="pp">test---prototype</p>
    <p>test---jQuery</p>
    
    <script type="text/javascript">
    jQuery.noConflict();  //将变量$的控制权让渡给prototype.js,全名可以不调用。
    jQuery(function(){   //使用jQuery
     jQuery("p").click(function(){
     alert( jQuery(this).text() );
     });
    });
    //此处不可以再写成$,此时的$代表prototype.js中定义的$符号。
    
    $("pp").style.display = 'none'; //使用prototype
    </script>

    2、自定义一个快捷方式

    noConflict() 可返回对 jQuery 的引用,可以把它存入自定义名称,例如jq,$J变量,以供稍后使用。

    这样可以确保jQuery不会与其他库冲突,同时又使用自定义一个快捷方式。

    <script type="text/javascript">
    var $j = jQuery.noConflict(); //自定义一个比较短快捷方式
    $j(function(){   //使用jQuery
     $j("p").click(function(){
     alert( $j(this).text() );
     });
    });
    
    $("pp").style.display = 'none'; //使用prototype
    </script>

    3、在不冲突的情况下仍然用$

    如果想在jQuery 代码块使用 $ 简写,不愿意改变这个快捷方式,可以把 $ 符号作为变量传递给 ready 方法。这样就可以在函数内使用 $ 符号了 , 而在函数外,依旧不得不使用 "jQuery"。

    <script type="text/javascript">
    jQuery.noConflict(); //将变量$的控制权让渡给prototype.js
    jQuery(document).ready(function($){
     $("p").click(function(){ //继续使用 $ 方法
     alert( $(this).text() );
     });
    });
    //或者如下
    jQuery(function($){   //使用jQuery
     $("p").click(function(){ //继续使用 $ 方法
     alert( $(this).text() );
     });
    });
    </script>

    或者使用IEF语句块,这应该是最理想的方式,因为可以通过改变最少的代码来实现全面的兼容性。

    在我们自己写jquery插件时,应该都使用这种写法,因为我们不知道具体工作过程中是如何顺序引入各种js库的,而这种语句块的写法却能屏蔽冲突。

    <script type="text/javascript">
    jQuery.noConflict();  //将变量$的控制权让渡给prototype.js
    (function($){   //定义匿名函数并设置形参为$
     $(function(){   //匿名函数内部的$均为jQuery
     $("p").click(function(){ //继续使用 $ 方法
      alert($(this).text());
     });
     });
    })(jQuery);    //执行匿名函数且传递实参jQuery
    
    $("pp").style.display = 'none'; //使用prototype
    </script>

    3、jQuery库在其他库之前导入

    jQuery库在其他库之前导入,$的归属权默认归后面的JavaScript库所有。那么可以直接使用"jQuery"来做一些jQuery的工作。

    同时,可以使用$()方法作为其他库的快捷方式。这里无须调用jQuery.noConflict()函数。

    <!-- 引入 jQuery -->
    <script src="../../scripts/jquery.js" type="text/javascript"></script>
    <!-- 引入 prototype -->
    <script src="lib/prototype.js" type="text/javascript"></script>
    
    <body>
    <p id="pp">Test-prototype(将被隐藏)</p>
    <p >Test-jQuery(将被绑定单击事件)</p>
    
    <script type="text/javascript">
    jQuery(function(){ //直接使用 jQuery ,没有必要调用"jQuery.noConflict()"函数。
     jQuery("p").click(function(){  
      alert( jQuery(this).text() );
     });
    });
    
    $("pp").style.display = 'none'; //使用prototype
    </script>
    </body>

    二、原理

    1、源码

    源码:看一下源码里怎么做到的

    var
    // Map over jQuery in case of overwrite
    _jQuery = window.jQuery,
    
    // Map over the $ in case of overwrite
    _$ = window.$,
    
    jQuery.extend({
     noConflict: function( deep ) {
       if ( window.$ === jQuery ) {
        window.$ = _$;
       }
    
       if ( deep && window.jQuery === jQuery ) {
        window.jQuery = _jQuery;
       }
    
       return jQuery;
      }
    });

    在jQuery加载的时候,通过事先声明的_jQuery变量获取到当前window.jQuery,通过_$获取到当前window.$。

    通过jQuery.extend()把noConflict挂载到jQuery下面。所以我们在调用的时候都是jQuery.noConflict()这样调。

    在调用noConflict()时做了2个判断,

    第一个if,把$的控制权交出去。

    第二个if,在noConflict()传参的时候把,jQuery的控制权交出去。

    最后noConflict()返回jQuery对象,用哪个参数接收,哪个参数将拥有jQuery的控制权。

    2、 验证

    //冲突 
     var $ = 123; //假设其他库中$为123
     $(
       function () {
        console.log($); //报错Uncaught TypeError: $ is not a function
       }
     );

    解决冲突

    //解决冲突
     var jq = $.noConflict();
     var $ = 123;
     jq(function () {
      alert($); //123
     });

    释放$控制权例子

    <script>
     var $ = 123; // window.$是123,存储在私有的_$上。
    
    </script>
    <script src="https://code.jquery.com/jquery-2.2.4.js"></script>
    <body>
    <p>aaa</p>
    <script>
     var jq = $.noConflict();//当window.$===jQuery的时候,把_$赋给了window.$。
     jq(function () {
      alert($); //123
     });
    </script>

    释放jQuery控制权例子

    参数deep的作用:deep用来放弃jQuery对外的接口。

    如下,noConflict()不写参数,弹出jQuery为构造函数。

    <script>
     var $ = 123;
     var jQuery=456;
    </script>
    <script src="https://code.jquery.com/jquery-2.0.3.js"></script>
    <body>
    <p>aaa</p>
    <script>
     var jq = $.noConflict();
     jq(function () {
      alert(jQuery); //构造函数
     });
    </script>


    如果写个参数true,会弹出456。

    <script>
     var $ = 123;
     var jQuery=456;
    </script>
    <script src="https://code.jquery.com/jquery-2.0.3.js"></script>
    <body>
    <p>aaa</p>
    <script>
     var jq = $.noConflict(true); //写了true或者参数的时候,deep为真window.jQuery===jQuery为真,所以进入if条件。把456赋值给window.jQuery
     jq(function () {
      alert(jQuery); //456
     });
    </script>

    相关推荐:

    使用jquery.noConflict()解决jquery库与其他库冲突的问题

    如何编写一个js/jQuery库(心得总结)

    jQuery库与其他JS库冲突的解决办法_jquery

    以上就是关于jQuery库冲突怎么办的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:jQuery 怎么办 冲突
    上一篇:ztree实现权限横向显示功能实例分享 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • 一文聊聊Angular中的依赖注入• Node实战学习:浏览器预览项目所有图片• react native路由跳转怎么实现• 一起聊聊var、let以及const的区别(代码示例)• 深入详解React中的ref
    1/1

    PHP中文网