jQuery多个版本和其他js库冲突的解决方法


Posted in Javascript onAugust 11, 2016

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本身就是区分大小写的。

以上所述是小编给大家介绍的jQuery多个版本和其他js库冲突的解决方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
jquery修改网页背景颜色通过css方法实现
Jun 06 Javascript
JS实现带关闭功能的阿里妈妈网站顶部滑出banner工具条代码
Sep 17 Javascript
第一次接触JS require.js模块化工具
Apr 17 Javascript
AngularJS应用开发思维之依赖注入3
Aug 19 Javascript
完美解决js传递参数中加号和&amp;号自动改变的方法
Oct 11 Javascript
js实现上传文件添加和删除文件选择框
Oct 24 Javascript
微信小程序实战之登录页面制作(5)
Mar 30 Javascript
Vue.js在使用中的一些注意知识点
Apr 29 Javascript
jQuery实现table表格checkbox全选的方法分析
Jul 04 jQuery
vue 根据选择条件显示指定参数的例子
Nov 09 Javascript
JS实现无限轮播无倒退效果
Sep 21 Javascript
vue+echarts+datav大屏数据展示及实现中国地图省市县下钻功能
Nov 16 Javascript
JS获取字符串实际长度(包含汉字)的简单方法
Aug 11 #Javascript
JavaScript性能优化之函数节流(throttle)与函数去抖(debounce)
Aug 11 #Javascript
JavaScript性能优化总结之加载与执行
Aug 11 #Javascript
js接收并转化Java中的数组对象的方法
Aug 11 #Javascript
Js调用Java方法并互相传参的简单实例
Aug 11 #Javascript
JS中的hasOwnProperty()、propertyIsEnumerable()和isPrototypeOf()
Aug 11 #Javascript
基于js对象,操作属性、方法详解
Aug 11 #Javascript
You might like
PHP Global变量定义当前页面的全局变量实现探讨
2013/06/05 PHP
浅析php工厂模式
2014/11/25 PHP
php将textarea数据提交到mysql出现很多空格的解决方法
2014/12/19 PHP
PHP 使用memcached简单示例分享
2015/03/05 PHP
基于swoole实现多人聊天室
2018/06/14 PHP
PHP使用观察者模式处理异常信息的方法详解
2019/09/24 PHP
TopList标签和JavaScript结合两例
2007/08/12 Javascript
ExtJS的FieldSet的column列布局
2009/11/20 Javascript
JS批量修改PS中图层名称的方法
2014/01/26 Javascript
jQuery.Uploadify插件实现带进度条的批量上传功能
2016/06/08 Javascript
JavaScript实现页面定时刷新(定时器,meta)
2016/10/12 Javascript
jQuery编写设置和获取颜色的插件
2017/01/09 Javascript
vue loadmore 组件滑动加载更多源码解析
2017/07/19 Javascript
vue学习之mintui picker选择器实现省市二级联动示例
2017/10/12 Javascript
react-redux中connect的装饰器用法@connect详解
2018/01/13 Javascript
Angular2进阶之如何避免Dom误区
2018/04/02 Javascript
微信小程序实现倒计时调用相机自动拍照功能
2018/06/10 Javascript
详解JSON和JSONP劫持以及解决方法
2019/03/08 Javascript
vue-cli3项目展示本地Markdown文件的方法
2019/06/07 Javascript
10种JavaScript最常见的错误(小结)
2019/06/21 Javascript
解决layui弹出层layer的area过大被遮挡的问题
2019/09/21 Javascript
vue中axios防止多次触发终止多次请求的示例代码(防抖)
2020/02/16 Javascript
[00:56]2014DOTA2国际邀请赛 DK、iG 赛前探访
2014/07/10 DOTA
[55:54]FNATIC vs EG 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/16 DOTA
python入门基础之用户输入与模块初认识
2016/11/14 Python
python存储16bit和32bit图像的实例
2018/12/05 Python
Python Tkinter 简单登录界面的实现
2019/06/14 Python
Python使用plt.boxplot() 参数绘制箱线图
2020/06/04 Python
python在地图上画比例的实例详解
2020/11/13 Python
friso美素佳儿官方海外旗舰店:荷兰原产原罐
2017/07/03 全球购物
StubHub希腊:购买体育赛事、音乐会和剧院门票
2019/08/03 全球购物
周年庆典主持词
2014/04/02 职场文书
公安局负责人查摆问题及整改方案
2014/09/27 职场文书
龙门石窟导游词
2015/02/02 职场文书
实习指导老师意见
2015/06/04 职场文书
诚信教育主题班会
2015/08/13 职场文书