位置: 编程技术 - 正文
推荐整理分享jQuery中 $ 符号的冲突问题及解决方案(jquery简写符号),希望有所帮助,仅作参考,欢迎阅读内容。
文章相关热门搜索词:jquery中$的作用,jquery中$的作用,jquery简写符号,jquery简写符号,jquery中$的作用,jquery简写符号,jquery中$的作用,jquery中$的作用,内容如对您有帮助,希望把文章链接给更多的朋友!
在jQuery中,$是jQuery的别名,为了书写方便,我们更习惯用$('#id')这一类的方式来书写代码。当同一页面引用了jQuery多个版本或者jQuery与某些其他js库产生冲突,控制台就会报错。
同一个页面多个版本冲突解决办法
你可能会问,为什么在一个页面上会引用多个版本的jQuery,只引用一个不就好了吗?
答案是:不行。一般要用到两个(或以上)版本的jQuery库的原因是:现有的网站已经用了旧版本的jQuery以及相关插件,直接将jQuery升级到新版本会导致这些基于旧版本jQuery的插件不能工作,除非你能把这些插件全部升级,或者等各个插件的作者发布支持新版本jQuery的插件版本。
解决办法:使用jQuery.noConflict([extreme])方法。
比如我引用的是jquery-1..0.js和jquery-1.5.0.js。
可以看到jQuery.noConflict将变量 $ 的控制权让渡给了1.5.0版本的jQuery库。而要使用1..0的版本则要用 $jq() 代替。
但是引入了两个版本的jQuery后,代码很乱,导致别人难以理解甚至误删了一些重要代码怎么办?
改进的方法是:
先直接引用新版的jQuery库。
把我们写的脚本myJS.js中的主体内容写在立即调用函数里头,引用的是新的版本的jQuery。
再写一个立即调用函数,把旧版本的jQuery代码嵌进去(压缩代码只有几行)。然后在里面写代码,此时变量$所引用的前面嵌进去的jQuery
Ps:需要检查jQuery的协议是否允许我们把jQuery源码直接嵌入我们自己的JavaScript代码
2. 同一页面jQuery和其他js库冲突解决方法
①依然可以使用jQuery.noConflict将变量$的控制权让渡给其他js库。
如果jQuery在其他js库前,不需要使用noConflict。
如果在其他js库之后,用noConflict让渡。
它的缺点是:在接下来的js代码中只要引用到jQuery就必须把$换成$jq。
②ready函数是jquery的入口函数
可以将
替换成:
它的缺点是:只对ready嵌套内的代码有效,如果ready函数外还有一些子函数,对嵌套外的代码是无效的。
③把$作为参数传进去
或者
你的js代码可以包括上面说到的ready函数和子函数。在用jQuery写公共组件的时候,使用这种方式既能避免$冲突,又无需要求使用公共组件的人修改自己的代码。
以上所述是小编给大家介绍的jQuery中 $ 符号的冲突问题及解决方案,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对积木网网站的支持!
jquery.Jcrop结合JAVA后台实现图片裁剪上传实例 本文介绍了头像裁剪上传功能,用到的技术有jQuery,springmvc,裁剪插件用的是jcrop(中间遇到很多坑,最终跨越)。图片上传步骤:1.用户选择图片2.将
jquery html5 视频播放控制代码 jQueryHTML5视频播放控制核心代码:videoclass="pause"controlsposter="images/vedio.jpg"width=""height=""sourcesrc="video/Defone3.8_1.mp4"type="video/mp4"您的浏览器不支持html5!/
jQuery Mobile和HTML5开发App推广注册页 jQueryMobile和HTML5的组合可以直接开发web版的app,所以用到我当前app中的推广注册页的编写是很恰当的,其实只要你熟悉html4+jquery的组合开发,那么html5+jquer
标签: jquery简写符号
本文链接地址:https://www.jiuchutong.com/biancheng/379297.html 转载请保留说明!友情链接: 武汉网站建设