• JQuery:通过noConflict()方法同时使用jQuery 和其他框架


    jQuery - noConflict()方法

    一、如何在页面上同时使用 jQuery 和其他框架?
    jQuery 和其他 JavaScript 框架
    正如您已经了解到的,jQuery 使用 $ 符号作为 jQuery 的简写。
    如果其他 JavaScript 框架也使用 $ 符号作为简写怎么办?
    其他一些 JavaScript 框架包括:MooTools、Backbone、Sammy、Cappuccino、Knockout、JavaScript MVC、Google Web Toolkit、Google Closure、Ember、Batman 以及 Ext JS。
    其中某些框架也使用 $ 符号作为简写(就像 jQuery),如果您在用的两种不同的框架正在使用相同的简写符号,有可能导致脚本停止运行。
    jQuery 的团队考虑到了这个问题,并实现了 noConflict() 方法。

    二、jQuery noConflict() 方法
    noConflict() 方法会释放会 $ 标识符的控制,这样其他脚本就可以使用它了。
    当然,您仍然可以通过全名替代简写的方式来使用 jQuery:
    实例1:
     $.noConflict();
    jQuery(document).ready(function(){
        jQuery("button").click(function(){
        jQuery("p").text("jQuery 仍然在工作!");
      });
    });
    代码如下:

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="utf-8">
        <script src="jquery-3.1.0.js"""></script>
        <script>
    $.noConflict(); jQuery(document).ready(function(){ jQuery("button").click(function(){ jQuery("p").text("jQuery 仍然在工作!"); }); }); </script> </head> <body> <p>这是一个段落。</p> <button>点我</button> </body> </html>

       

    您也可以创建自己的简写。noConflict() 可返回对 jQuery 的引用,您可以把它存入变量,以供稍后使用。请看这个例子:
    实例2:
    var jq = $.noConflict();
      jq(document).ready(function(){
      jq("button").click(function(){
        jq("p").text("jQuery 仍然在工作!");
      });
    });
    代码如下:

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="utf-8">
        <script src="jquery-3.1.0.js"""></script>
        <script>
            var jq=$.noConflict();
            jq(document).ready(function(){
              jq("button").click(function(){
                jq("p").text("jQuery 仍然在工作!");
              });
            });
        </script>
    </head>
    
    <body>
        <p>这是一个段落。</p>
        <button>点我</button>
    </body>
    </html>

     

    如果你的 jQuery 代码块使用 $ 简写,并且您不愿意改变这个快捷方式,那么您可以把 $ 符号作为变量传递给 ready 方法。这样就可以在函数内使用 $ 符号了 - 而在函数外,依旧不得不使用 "jQuery":
    实例3:
    $.noConflict();
      jQuery(document).ready(function($){
        $("button").click(function(){
        ("p").text("jQuery 仍然在工作!");
      });
    });
    代码如下:

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="utf-8">
        <script src="jquery-3.1.0.js"""></script>
        <script>
            $.noConflict();
            jQuery(document).ready(function($){
              $("button").click(function(){
                $("p").text("jQuery 仍然在工作!");
              });
            });
        </script>
    </head>
    
    <body>
        <p>这是一个段落。</p>
        <button>点我</button>
    </body>
    </html>

     

  • 相关阅读:
    CodeForces19D:Points(线段树+set(动态查找每个点右上方的点))
    CodeForces-816B:Karen and Coffee (简单线段树)
    CodeForces292D:Connected Components (不错的并查集)
    CodeForces546D:Soldier and Number Game(筛区间素数因子个数和)
    CoderForces343D:Water Tree(dfs序+线段树&&特殊处理)
    HihoCoder1706 : 末尾有最多0的乘积(还不错的DP)
    HihoCoder1705: 座位问题(STL)
    【CQ18阶梯赛第8场】题解
    阿里开源 Dragonwell JDK 重磅发布 GA 版本:生产环境可用
    5年时间,我从开发做到总裁的秘籍--如何提升技术型管理者的领导力
  • 原文地址:https://www.cnblogs.com/XYQ-208910/p/5903972.html
Copyright © 2020-2023  润新知