zoukankan      html  css  js  c++  java
  • 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>

     

  • 相关阅读:
    linux
    JAVA——遍历
    linux基础命令
    Java的反射和代理以及注解
    web 前端遇到的问题
    JTopo 使用
    阿里云服务器linux(cenos)下 jdk、tomcat的安装配置
    笔记--数据库总结
    0.01的区别
    犹豫——辛苦——坚持——收获 (2019北航软工培训总结)
  • 原文地址:https://www.cnblogs.com/XYQ-208910/p/5903972.html
Copyright © 2011-2022 走看看