前言
一次面试中面试官问到jQuery和别的库冲突怎么解决?虽然以前看过,但是我已经不记得了。
我的思路就是如果让我来设计,那我就用一个默认值$,不传参数,那就用$,最后就挂载在window.$
上,传参数就用传入名字,比如传入jq,那我就挂载在window.jq
上。
var myControl="jq"; (function(name){ var $=name ||"$"; //name存在$的值就是name的值,不存在或为null,$的值为字符串"$" console.log($); window[$]=function(){ alert("123"); } })(myControl) window[myControl]();
事实上这肯定不是jquery解决冲突的办法了。那就看看jQuery怎么解决冲突吧。
jQuery多个版本或和其他js库冲突主要是常用的$符号的冲突。
一、冲突的解决
1、同一页面jQuery多个版本冲突解决方法
<body> <!-- 引入1.6.4版的jq --> <script src="/UploadFiles/2021-04-02/jquery.js">2、jQuery库在其他库之后导入
jQuery noConflict()
方法会释放会 $ 标识符的控制,这样其他脚本就可以使用它了。1、可以通过jQuery全名替代简写的方式来使用 jQuery
在其他库和jQuery库都加载完毕后,可以在任何时候调用
jQuery.noConflict()
函数来将变量$的控制权移交给其他JavaSript库。然后就可以在程序里将jQuery()
函数作为jQuery对象的制造工厂。<script src="/UploadFiles/2021-04-02/prototype.js">2、自定义一个快捷方式
noConflict()
可返回对 jQuery 的引用,可以把它存入自定义名称,例如jq,$J变量,以供稍后使用。这样可以确保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>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>或者使用IEF语句块,这应该是最理想的方式,因为可以通过改变最少的代码来实现全面的兼容性。
在我们自己写jquery插件时,应该都使用这种写法,因为我们不知道具体工作过程中是如何顺序引入各种js库的,而这种语句块的写法却能屏蔽冲突。
<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>3、jQuery库在其他库之前导入
jQuery库在其他库之前导入,$的归属权默认归后面的JavaScript库所有。那么可以直接使用"jQuery"来做一些jQuery的工作。
同时,可以使用
$()
方法作为其他库的快捷方式。这里无须调用jQuery.noConflict()
函数。<!-- 引入 jQuery --> <script src="/UploadFiles/2021-04-02/jquery.js">二、原理
1、源码
源码:看一下源码里怎么做到的
var // Map over jQuery in case of overwrite _jQuery = window.jQuery, // Map over the $ in case of overwrite _$ = window.$, jQuery.extend({ noConflict: function( deep ) { if ( window.$ === jQuery ) { window.$ = _$; } if ( deep && window.jQuery === jQuery ) { window.jQuery = _jQuery; } return jQuery; } });在jQuery加载的时候,通过事先声明的_jQuery变量获取到当前
window.jQuery
,通过_$获取到当前window.$
。通过
jQuery.extend()
把noConflict挂载到jQuery下面。所以我们在调用的时候都是jQuery.noConflict()
这样调。在调用
noConflict()
时做了2个判断,第一个if,把$的控制权交出去。
第二个if,在
noConflict()
传参的时候把,jQuery的控制权交出去。最后
noConflict()
返回jQuery对象,用哪个参数接收,哪个参数将拥有jQuery的控制权。2、 验证
//冲突 var $ = 123; //假设其他库中$为123 $( function () { console.log($); //报错Uncaught TypeError: $ is not a function } );解决冲突
//解决冲突 var jq = $.noConflict(); var $ = 123; jq(function () { alert($); //123 });释放$控制权例子
<script> var $ = 123; // window.$是123,存储在私有的_$上。 </script> <script src="/UploadFiles/2021-04-02/jquery-2.2.4.js">释放jQuery控制权例子
参数deep的作用:deep用来放弃jQuery对外的接口。
如下,
noConflict()
不写参数,弹出jQuery为构造函数。广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!暂无评论...
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]