今回は、jQuery ライブラリを使用する際の注意事項について詳しく説明します。以下は実際のケースです。
まえがき
インタビュー中、インタビュアーは、jQuery と他のライブラリ間の競合を解決する方法を尋ねました。以前にも見たことがあるのですが、もう覚えていません。
私のアイデアは、私に設計させてもらえれば、デフォルト値の $ を使用し、パラメーターを渡さない場合は $ を使用することです。最後に、それを window.$ にパラメータを渡すだけです。jq などの名前を渡すと、それを <code>window.jq
にマウントします。 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="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>
2、jQuery库在其他库之后导入
jQuery noConflict()
方法会释放会 $ 标识符的控制,这样其他脚本就可以使用它了。
1、可以通过jQuery全名替代简写的方式来使用 jQuery
在其他库和jQuery库都加载完毕后,可以在任何时候调用jQuery.noConflict()
函数来将变量$的控制权移交给其他JavaSript库。然后就可以在程序里将jQuery()
函数作为jQuery对象的制造工厂。
<script src="prototype.js" type="text/javascript"></script> <script src="jquery.js" type="text/javascript"></script> <p id="pp">test---prototype</p> <p>test---jQuery</p> <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、自定义一个快捷方式
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="../../scripts/jquery.js" type="text/javascript"></script> <!-- 引入 prototype --> <script src="lib/prototype.js" type="text/javascript"></script> <body> <p id="pp">Test-prototype(将被隐藏)</p> <p >Test-jQuery(将被绑定单击事件)</p> <script type="text/javascript"> jQuery(function(){ //直接使用 jQuery ,没有必要调用"jQuery.noConflict()"函数。 jQuery("p").click(function(){ alert( jQuery(this).text() ); }); }); $("pp").style.display = 'none'; //使用prototype </script> </body>
二、原理
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="https://code.jquery.com/jquery-2.2.4.js"></script> <body> <p>aaa</p> <script> var jq = $.noConflict();//当window.$===jQuery的时候,把_$赋给了window.$。 jq(function () { alert($); //123 }); </script>
释放jQuery控制权例子
参数deep的作用:deep用来放弃jQuery对外的接口。
如下,noConflict()
<script> var $ = 123; var jQuery=456; </script> <script src="https://code.jquery.com/jquery-2.0.3.js"></script> <body> <p>aaa</p> <script> var jq = $.noConflict(); jq(function () { alert(jQuery); //构造函数 }); </script>
<script> var $ = 123; var jQuery=456; </script> <script src="https://code.jquery.com/jquery-2.0.3.js"></script> <body> <p>aaa</p> <script> var jq = $.noConflict(true); //写了true或者参数的时候,deep为真window.jQuery===jQuery为真,所以进入if条件。把456赋值给window.jQuery jq(function () { alert(jQuery); //456 }); </script>
jQuery noConflict()
メソッドは $ 識別子の制御を解放し、他のスクリプトがそれを使用できるようにします。 🎜🎜1. jQuery の略語を正式名に置き換えて使用できます🎜🎜他のライブラリと jQuery ライブラリがロードされた後は、いつでも jQuery.noConflict()
関数を呼び出して変更できます。 $ の変数 Control は他の JavaScript ライブラリに転送されます。その後、プログラム内で jQuery()
関数を jQuery オブジェクトの製造ファクトリとして使用できます。 🎜rrreee🎜2. ショートカットをカスタマイズする🎜🎜noConflict()
は jQuery への参照を返すことができ、後で使用するために jq、$J 変数などのカスタム名で保存できます。 🎜🎜これにより、カスタマイズされたショートカットを使用しているときに、jQuery が他のライブラリと競合しないことが保証されます。 🎜rrreee🎜3. 競合がない場合は引き続き $ を使用します🎜🎜 jQuery コード ブロックで $ 省略形を使用したいが、このショートカットを変更したくない場合は、$ 記号を変数として ready メソッドに渡すことができます。このように、関数内では $ 記号を使用できますが、関数の外では引き続き「jQuery」を使用する必要があります。 🎜rrreee🎜 または、IEF ステートメント ブロックを使用します。これは、最小限のコード変更で完全な互換性を実現できるため、最も理想的な方法です。 🎜🎜私たちが独自の jquery プラグインを作成するときは、この記述方法を使用する必要があります。特定の作業プロセス中にさまざまな js ライブラリを順番に導入する方法がわからないためですが、このステートメント ブロックの記述方法は競合を防ぐことができます。 🎜rrreee🎜3. jQuery ライブラリは他のライブラリよりも先にインポートされます。 🎜🎜🎜 $ の所有権は、デフォルトでは次の JavaScript ライブラリに属します。その後、「jQuery」を直接使用して jQuery の作業を行うことができます。 🎜🎜同時に、$()
メソッドを他のライブラリへのショートカットとして使用できます。ここで jQuery.noConflict()
関数を呼び出す必要はありません。 🎜rrreee🎜2. 原則🎜🎜🎜1. ソース コード🎜🎜🎜 でその方法を見てください。ソースコード🎜rrreee🎜 jQueryがロードされると、事前に宣言された_jQuery変数を通じて現在のwindow.jQuery
が取得され、_$を通じて現在のwindow.$
が取得されます。 。 🎜🎜jQuery.extend()
を通じて noConflict を jQuery にマウントします。したがって、これを呼び出すときは、常に次のように調整します: jQuery.noConflict()
。 🎜🎜noConflict()
を呼び出すときに 2 つの判断を行いました。🎜🎜最初の if は $ の制御を渡します。 🎜🎜 2 番目の if は、noConflict()
でパラメータを渡すときに jQuery の制御を渡します。 🎜🎜最後に、noConflict()
は jQuery オブジェクトを返します。そのオブジェクトを受け取るためにどのパラメーターが使用され、どのパラメーターが jQuery 制御を持つことになります。 🎜🎜2. 検証🎜🎜rrreee🎜競合を解決する🎜rrreee🎜 $ コントロールの例を解放する🎜rrreee🎜 jQuery コントロールの例を解放する🎜🎜 パラメータ deep の役割: deep は、jQuery の外部インターフェイスを放棄するために使用されます。 🎜🎜 以下のように、noConflict()
はパラメーターを書き込まず、jQuery が🎜コンストラクター🎜としてポップアップします。 🎜<script> var $ = 123; var jQuery=456; </script> <script src="https://code.jquery.com/jquery-2.0.3.js"></script> <body> <p>aaa</p> <script> var jq = $.noConflict(); jq(function () { alert(jQuery); //构造函数 }); </script>
如果写个参数true,会弹出456。
<script> var $ = 123; var jQuery=456; </script> <script src="https://code.jquery.com/jquery-2.0.3.js"></script> <body> <p>aaa</p> <script> var jq = $.noConflict(true); //写了true或者参数的时候,deep为真window.jQuery===jQuery为真,所以进入if条件。把456赋值给window.jQuery jq(function () { alert(jQuery); //456 }); </script>
相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!
推荐阅读:
以上が影響を受ける場合の jQuery ライブラリの使用に関する詳細な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。