在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中 $ 符号的冲突问题及解决方案,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对小牛知识库网站的支持!
本文向大家介绍linux 下同名符号冲突问题解决方案,包括了linux 下同名符号冲突问题解决方案的使用技巧和注意事项,需要的朋友参考一下 linux 下同名符号冲突问题解决方案 最近的工作中遇到如下令人蛋疼的问题: Linux 下有三个模块aa、bb、cc,基本情况如下: cc 编译连接得到 cc.so 动态库,cc 中有如下接口: bb 编译连接得到 bb.a 静态库,bb 中有如下接口: a
本文向大家介绍jquery UI Datepicker时间控件冲突问题解决,包括了jquery UI Datepicker时间控件冲突问题解决的使用技巧和注意事项,需要的朋友参考一下 公司里的项目由于发展较快,很多东西都没有好好梳理一下,以至于有很多的潜在的问题。 最近就遇到了一个比较坑的问题。datepicker 有两个插件库中的datepicker插件比较有名。一个是jQuery-UI,一个
本文向大家介绍python3.8与pyinstaller冲突问题的快速解决方法,包括了python3.8与pyinstaller冲突问题的快速解决方法的使用技巧和注意事项,需要的朋友参考一下 安装pyinstaller 安装的时候 进入cmd pip install pyinstaller 发现安装报错! 解决办法: # 自主下载pyinstaller包,进行手动安装 pyinstaller 的下
本文向大家介绍onclick和onblur冲突问题的快速解决方法,包括了onclick和onblur冲突问题的快速解决方法的使用技巧和注意事项,需要的朋友参考一下 新浪首页的搜索框里面有一个使用ajax的下拉框。我们需要实现一个点击下拉框里面的一项,让搜索框里面的值变成这一项,同时下拉框消失的效果,但同时在点击其他地方的时候,这个下拉框也要消失。大致如图: 我们同时使用onblur和onclick
Windows 用tutorial进行的操作 若要进行pull操作,请右击tutorial目录,并选择‘拉取’。 用tutorial进行的操作 在以下画面点击‘确定’。 用tutorial进行的操作 我们看到画面上的警告信息表示自动合并失败。请点击‘关闭’以退出窗口。 用tutorial进行的操作 若您确认变更,请点击‘Yes’。 用tutorial进行的操作 TortoiseGit告诉我们:因"
在上一个页面我们提及到,执行合并即可自动合并Git修改的部分。但是,也存在无法自动合并的情况。 如果远程数据库和本地数据库的同一个地方都发生了修改的情况下,因为无法自动判断要选用哪一个修改,所以就会发生冲突。 Git会在发生冲突的地方修改文件的内容,如下图。所以我们需要手动修正冲突。 ==分割线上方是本地数据库的内容, 下方是远程数据库的编辑内容。 如下图所示,修正所有冲突的地方之后,执行提交。