Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 32026|回复: 0

解决jQuery多个版本,与其他js库冲突方法

[复制链接]
  • TA的每日心情
    奋斗
    2024-4-6 11:05
  • 签到天数: 748 天

    [LV.9]以坛为家II

    2034

    主题

    2092

    帖子

    70万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    705612
    发表于 2021-4-5 17:23:14 | 显示全部楼层 |阅读模式

    jQuery多个版本或和其他js库冲突主要是常用的$符号的问题,这个问题 jquery早早就有给我们预留处理方法了,下面一起来看看解决办法。

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

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="utf-8" />
        <title>jQuery测试页</title>
    </head>
    <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> </html>

     

    2.同一页面jQuery和其他js库冲突解决方法

    jQuery noConflict() 方法
    noConflict() 方法会释放会 $ 标识符的控制,这样其他脚本就可以使用它了。
    jquery.js在prototype.js之前进行引入,如:

    <script src="jquery.js" type="text/javascript"></script>
    <script src="prototype.js" type="text/javascript"></script>
    <p id="pp">test---prototype</p>
    <p>test---jQuery</p>

    2.1 当然,您仍然可以通过全名替代简写的方式来使用 jQuery:

    <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.2  您也可以创建自己的简写。noConflict() 可返回对 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>

    2.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>

    2.4 使用语句块:

    <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>

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

     

    注意:
    1.引用javascript类库时,把jQuery引用放在最后面,可以避免冲突。
    2.特别要注意jQuery()代替$()时,jQuery是区分大小写的,因为javascript本身就是区分大小写的。

     

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-4-18 13:00 , Processed in 0.077716 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表