jQuery中 $ 符号的冲突问题及解决方案


Posted in Javascript onNovember 04, 2016

在jQuery中,$是jQuery的别名,为了书写方便,我们更习惯用$('#id')这一类的方式来书写代码。当同一页面引用了jQuery多个版本或者jQuery与某些其他js库产生冲突,控制台就会报错。

同一个页面多个版本冲突解决办法

你可能会问,为什么在一个页面上会引用多个版本的jQuery,只引用一个不就好了吗?

答案是:不行。一般要用到两个(或以上)版本的jQuery库的原因是:现有的网站已经用了旧版本的jQuery以及相关插件,直接将jQuery升级到新版本会导致这些基于旧版本jQuery的插件不能工作,除非你能把这些插件全部升级,或者等各个插件的作者发布支持新版本jQuery的插件版本。

解决办法:使用jQuery.noConflict([extreme])方法。

比如我引用的是jquery-1.11.0.js和jquery-1.5.0.js。

<script src="jquery-1.5.0.js"></script>
<script src="jquery-1.11.0.js"></script>
<script>
console.log($.fn.jquery); //'1.11.0'
var $jq = jQuery.noConflict(true);
console.log($.fn.jquery); //'1.5.0'
</script>

可以看到jQuery.noConflict将变量 $ 的控制权让渡给了1.5.0版本的jQuery库。而要使用1.11.0的版本则要用 $jq() 代替。

但是引入了两个版本的jQuery后,代码很乱,导致别人难以理解甚至误删了一些重要代码怎么办?

改进的方法是:

先直接引用新版的jQuery库。

<script src="jquery-1.11.0.js"></script>
<script src="myJS.js"></script>

把我们写的脚本myJS.js中的主体内容写在立即调用函数里头,引用的是新的版本的jQuery。

//myJS.js
(function() {
//myJS.js的代码,引用的是v1.11.0
})();

再写一个立即调用函数,把旧版本的jQuery代码嵌进去(压缩代码只有几行)。然后在里面写代码,此时变量$所引用的前面嵌进去的jQuery

//myJS.js
(function () {
//...此处省略/jquery1.5.0
//jquery1.5.0的压缩代码
var $ = jQuery.noConflict(true);
//此处开始写的$()所引用的是jquery1.5.0
})();

Ps:需要检查jQuery的协议是否允许我们把jQuery源码直接嵌入我们自己的JavaScript代码

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

①依然可以使用jQuery.noConflict将变量$的控制权让渡给其他js库。

如果jQuery在其他js库前,不需要使用noConflict。 

<!-- 引入 jquery库 -->
<script src="jquery-1.11.0.js"></script>
<script type="text/javascript">
var $jq = $;
console.log($.fn.jquery); //'1.11.0'
</script>
<!-- 引入 其他库-->
<script type="text/javascript">
$ = {
fn:{
jquery:"otherJS"
}
};
</script>
<script type="text/javascript"> 
console.log($.fn.jquery); //otherJS
console.log($jq.fn.jquery); //'1.11.0'
</script>

如果在其他js库之后,用noConflict让渡。

<!-- 引入 其他库-->
<script type="text/javascript">
$ = {
fn:{
jquery:"otherJS"
}
};
</script>
<!-- 引入 jquery库 -->
<script src="jquery-1.11.0.js"></script>
<script type="text/javascript"> 
console.log($.fn.jquery); //'1.11.0'
var $180 = $.noConflict(); //解除冲突
console.log($.fn.jquery); //otherJS
console.log($jq.fn.jquery); //'1.11.0'
</script>

它的缺点是:在接下来的js代码中只要引用到jQuery就必须把$换成$jq。

②ready函数是jquery的入口函数

可以将

$(document).ready(function() {...})

替换成:

jQuery(document).ready(function($) {...})

它的缺点是:只对ready嵌套内的代码有效,如果ready函数外还有一些子函数,对嵌套外的代码是无效的。

③把$作为参数传进去

(function($) { 
//你的js代码 
})(jQuery);

或者

jQuery(function($){ 
//你的js代码
}

你的js代码可以包括上面说到的ready函数和子函数。在用jQuery写公共组件的时候,使用这种方式既能避免$冲突,又无需要求使用公共组件的人修改自己的代码。

以上所述是小编给大家介绍的jQuery中 $ 符号的冲突问题及解决方案,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
javascript下利用arguments实现string.format函数
Aug 24 Javascript
javascript 基础篇1 什么是js 建立第一个js程序
Mar 14 Javascript
angularjs实现与服务器交互分享
Jun 24 Javascript
JavaScript的9种继承实现方式归纳
May 18 Javascript
AngularJs实现ng1.3+表单验证
Dec 10 Javascript
Kindeditor在线文本编辑器如何过滤HTML
Apr 14 Javascript
Three.js学习之几何形状
Aug 01 Javascript
HTML5 实现的一个俄罗斯方块实例代码
Sep 19 Javascript
Vue完整项目构建(进阶篇)
Feb 10 Javascript
如何利用node.js开发一个生成逐帧动画的小工具
Dec 01 Javascript
聊聊vue 中的v-on参数问题
Jan 29 Vue.js
JavaScript实现登录窗体
Jun 22 Javascript
JAVA Web实时消息后台服务器推送技术---GoEasy
Nov 04 #Javascript
详解js运算符单竖杠“|”与“||”的用法和作用介绍
Nov 04 #Javascript
使用Ajax与服务器(JSON)通信实例
Nov 04 #Javascript
AngularJS过滤器filter用法实例分析
Nov 04 #Javascript
URL的参数中有加号传值变为空格的问题(URL特殊字符)
Nov 04 #Javascript
Angular页面间切换及传值的4种方法
Nov 04 #Javascript
AngularJS实现根据变量改变动态加载模板的方法
Nov 04 #Javascript
You might like
如何做到多笔资料的同步
2006/10/09 PHP
php中利用post传递字符串重定向的实现代码
2011/04/21 PHP
php学习之function的用法
2012/07/14 PHP
浅谈php+phpStorm+xdebug配置方法
2015/09/17 PHP
Zend Framework教程之响应对象的封装Zend_Controller_Response实例详解
2016/03/07 PHP
yii2使用GridView实现数据全选及批量删除按钮示例
2017/03/01 PHP
PHP四种排序算法实现及效率分析【冒泡排序,插入排序,选择排序和快速排序】
2018/04/27 PHP
理解JavaScript的prototype属性
2012/02/11 Javascript
网页防止tab键的使用快速解决方法
2013/11/07 Javascript
jQuery的DOM操作之删除节点示例
2014/01/03 Javascript
图片放大镜jquery.jqzoom.js使用实例附放大镜图标
2014/06/19 Javascript
JS使用post提交的两种方式
2015/12/03 Javascript
JS组件Bootstrap实现弹出框和提示框效果代码
2015/12/08 Javascript
JS判断字符串字节数并截取长度的方法
2016/03/05 Javascript
超全面的vue.js使用总结
2017/02/12 Javascript
jQuery编写textarea输入字数限制代码
2017/03/23 jQuery
JS身份证信息验证正则表达式
2017/06/12 Javascript
JavaScript之class继承_动力节点Java学院整理
2017/07/03 Javascript
解决VantUI popup 弹窗不弹出或无蒙层的问题
2020/11/03 Javascript
vue 封装面包屑组件教程
2020/11/16 Javascript
[44:50]2018DOTA2亚洲邀请赛 4.1 小组赛 A组 TNC vs VG
2018/04/02 DOTA
Python2.x版本中maketrans()方法的使用介绍
2015/05/19 Python
Python Numpy数组扩展repeat和tile使用实例解析
2019/12/09 Python
详谈tensorflow gfile文件的用法
2020/02/05 Python
python利用os模块编写文件复制功能——copy()函数用法
2020/07/13 Python
美国咖啡批发网站:Coffee.org
2017/06/29 全球购物
美国女士时尚珠宝及配饰购物网站:Icing
2018/07/02 全球购物
应届行政管理专业个人自我评价
2013/12/28 职场文书
三查三看党性分析材料
2014/02/18 职场文书
团代会开幕词
2015/01/28 职场文书
个人先进事迹总结
2015/02/26 职场文书
2015年小学辅导员工作总结
2015/05/27 职场文书
学术研讨会主持词
2015/07/04 职场文书
公司考勤管理制度
2015/08/04 职场文书
Python中的min及返回最小值索引的操作
2021/05/10 Python
Django数据库(SQlite)基本入门使用教程
2022/07/07 Python