最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
解决同一页面jQuery多个版本或和其他js库冲突方法
时间:2022-06-25 17:48:13 编辑:袖梨 来源:一聚教程网
1.同一页面jQuery多个版本或冲突解决方法
代码如下 | 复制代码 |
|
2.同一页面jQuery和其他js库冲突解决方法
①.jQuery在其他js库前
代码如下 | 复制代码 |
|
②.jQuery在其他js库后
代码如下 | 复制代码 |
|
再补充一下方法
方案1:
引入noConflict(),将$替换为其他符号
代码如下 | 复制代码 |
var $j = jQuery.noConflict(); $j(document).ready(function(){ $j("#btn1").click(function(){ alert("Text: " + $j("#test").text()); }); }); |
缺点:引入了这段代码后,不仅是当前的js文件,该html引用的所有js中,如果有用到jquery中的$,都得用$j来代替之前的$
方案2:
代码如下 | 复制代码 |
ready函数是jquery的入口函数,可以 将$(document).ready(function(){ 替换成 jQuery( document ).ready(function( $){} |
缺点:只对ready嵌套内的代码有效,对嵌套外的代码是无效的。如果你所有的逻辑,都在写ready函数中,那没问题。但我们一般都会在ready函数之外写一些子函数,然后ready函数再去调用这些函数。这个方案对这些函数是无效的,因此这套方案有局限性。
方案3(推荐,特别是开发js插件时):
给js内容包上一个函数
代码如下 | 复制代码 |
或者
|
这个方法,没有上面两个方案的缺点,只会影响到被包在jQuery(function($){}中的代码。
不会影响到其他js代码,这一点很重要。试想一下,假如你写了一个js公共组件,该组件需要用到jquery,为了提高鲁棒性,需考虑$符号冲突问题。如果使用方案1,那么别人在使用时,还得遵守你的约定,把自己js代码中的$改成$,而如果使用方案3,既能避免$冲突对该组件的影响,又无需要求使用公共组件的人修改自己的代码。
相关文章
- 无限暖暖搭乘大鸟巴士怎么玩 公测第三天每日任务做法介绍 12-27
- 奇迹暖暖绚光护佑搭配攻略 奇迹暖暖绚光护佑过关攻略 12-27
- 绝区零月城柳意像影画怎么样 12-27
- 无限暖暖翩翩愿飞去怎么样 12-27
- 黑神话悟空1.0.12.16581版本更新公告 12-27
- 光遇12.27红石碎片在哪里 12-27