検索
ホームページウェブフロントエンドjsチュートリアルjQueryライブラリの競合についてどうするか

jQueryライブラリの競合についてどうするか

Jan 11, 2018 pm 02:08 PM
jquery対立何をするか

jQuery で開発する場合、Prototype などの他の JS ライブラリを使用することもできますが、複数のライブラリが共存すると競合が発生する可能性があります。この記事では主に jQuery ライブラリの競合に対する完璧な解決策を紹介します。必要な方は参考にしてください。以下をご覧ください。

私の考えは、デザインを依頼された場合は、デフォルト値の $ を使用することです。パラメーターが渡されない場合は、$ を使用します。最後に、パラメーターを渡すときは、$ を使用します。たとえば、「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. 競合の解決

1. 同じページ上の複数のバージョンの jQuery 間の競合を解決する方法

2. 他のライブラリの後に jQuery ライブラリをインポートします

jQuery noConflict() メソッドが制御を解放します。 $ identifier なので、他のスクリプトでもそれを使用できます。

1. jQuery の略語を正式名に置き換えることで使用できます

他のライブラリと jQuery ライブラリがロードされた後は、いつでも jQuery.noConflict() 関数を呼び出して、変数 $ の制御を他のライブラリに移すことができます。ライブラリ。その後、プログラム内で jQuery() 関数を jQuery オブジェクトの製造ファクトリーとして使用できます。

<!-- 引入1.6.4版的jq -->
<script></script>
<script> var jq164 = jQuery.noConflict(true); </script>
<!-- 引入1.4.2版的jq -->
<script></script>
<script> var jq142 = jQuery.noConflict(true); </script>

<script>
(function($){
 //此时的$是jQuery-1.6.4
 $(&#39;#&#39;);
})(jq164);
</script>
 
<script>
jq142(function($){
 //此时的$是jQuery-1.4.2
 $(&#39;#&#39;);
});
</script>
 

2. ショートカットをカスタマイズする

noConflict() は、jQuery への参照を返すことができ、後で使用するために、jq、$J 変数などのカスタム名で保存できます。

これにより、カスタマイズされたショートカットの使用中に jQuery が他のライブラリと競合しないことが保証されます。

<script></script>
<script></script>

<p>test---prototype</p>
<p>test---jQuery</p>

<script>
jQuery.noConflict();  //将变量$的控制权让渡给prototype.js,全名可以不调用。
jQuery(function(){   //使用jQuery
 jQuery("p").click(function(){
 alert( jQuery(this).text() );
 });
});
//此处不可以再写成$,此时的$代表prototype.js中定义的$符号。

$("pp").style.display = &#39;none&#39;; //使用prototype
</script>

3. 競合がない場合は引き続き $ を使用します

jQuery コード ブロックで $ 省略形を使用したいが、このショートカットを変更したくない場合は、$ 記号を変数として ready メソッドに渡すことができます。このように、関数内では $ 記号を使用できますが、関数の外では引き続き「jQuery」を使用する必要があります。

<script>
var $j = jQuery.noConflict(); //自定义一个比较短快捷方式
$j(function(){   //使用jQuery
 $j("p").click(function(){
 alert( $j(this).text() );
 });
});

$("pp").style.display = &#39;none&#39;; //使用prototype
</script>

または、IEF ステートメント ブロックを使用します。これは、最小限のコード変更で完全な互換性を実現できるため、最も理想的な方法です。

私たちが独自の jquery プラグインを作成するときは、この記述方法を使用する必要があります。特定の作業プロセス中にさまざまな js ライブラリを順番に導入する方法がわからないためですが、このステートメント ブロックの記述方法は競合を防ぐことができます。

<script>
jQuery.noConflict(); //将变量$的控制权让渡给prototype.js
jQuery(document).ready(function($){
 $("p").click(function(){ //继续使用 $ 方法
 alert( $(this).text() );
 });
});
//或者如下
jQuery(function($){   //使用jQuery
 $("p").click(function(){ //继续使用 $ 方法
 alert( $(this).text() );
 });
});
</script>

3. jQuery ライブラリは他のライブラリよりも先にインポートされます。

$ の所有権は、デフォルトでは次の JavaScript ライブラリに属します。その後、「jQuery」を直接使用して jQuery の作業を行うことができます。

同時に、$() メソッドを他のライブラリへのショートカットとして使用できます。ここで jQuery.noConflict() 関数を呼び出す必要はありません。

<script>
jQuery.noConflict();  //将变量$的控制权让渡给prototype.js
(function($){   //定义匿名函数并设置形参为$
 $(function(){   //匿名函数内部的$均为jQuery
 $("p").click(function(){ //继续使用 $ 方法
  alert($(this).text());
 });
 });
})(jQuery);    //执行匿名函数且传递实参jQuery

$("pp").style.display = &#39;none&#39;; //使用prototype
</script>

2. 原則

1. ソースコード

ソースコード: ソースコードでどのように行われるかを見てください

<!-- 引入 jQuery -->
<script></script>
<!-- 引入 prototype -->
<script></script>


<p>Test-prototype(将被隐藏)</p>
<p>Test-jQuery(将被绑定单击事件)</p>

<script>
jQuery(function(){ //直接使用 jQuery ,没有必要调用"jQuery.noConflict()"函数。
 jQuery("p").click(function(){  
  alert( jQuery(this).text() );
 });
});

$("pp").style.display = &#39;none&#39;; //使用prototype
</script>

jQuery がロードされると、現在の window.jQuery が _jQuery 変数を通じて取得されます事前に宣言し、_ $現在のウィンドウを取得します。$

jQuery.extend() を通じて noConflict を jQuery にマウントします。そのため、呼び出すときは常に jQuery.noConflict() をこのように調整します。

noConflict() を呼び出すときに 2 つの判断を行います

最初の if は $ の制御を渡します。

2 番目の if は、noConflict() がパラメーターを渡すときに jQuery の制御を渡します。

最後に、 noConflict() は jQuery オブジェクトを返します。そのオブジェクトを受け取るためにどのパラメーターが使用され、どのパラメーターが jQuery 制御を持ちますか。

2. 検証

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;
  }
});

競合を解決する

//冲突 
 var $ = 123; //假设其他库中$为123
 $(
   function () {
    console.log($); //报错Uncaught TypeError: $ is not a function
   }
 );

$コントロールを解放する例

//解决冲突
 var jq = $.noConflict();
 var $ = 123;
 jq(function () {
  alert($); //123
 });

jQueryコントロールを解放する例

パラメータ deep: deep の役割は、jQuery の外部インターフェイスを放棄するために使用されます。

以下のように、noConflict()はパラメータを書き込まず、コンストラクタとしてjQueryをポップアップします。

<script>
 var $ = 123; // window.$是123,存储在私有的_$上。

</script>
<script></script>

<p>aaa</p>
<script>
 var jq = $.noConflict();//当window.$===jQuery的时候,把_$赋给了window.$。
 jq(function () {
  alert($); //123
 });
</script>


パラメータtrueを書くと456が出てきます。

<script>
 var $ = 123;
 var jQuery=456;
</script>
<script></script>

<p>aaa</p>
<script>
 var jq = $.noConflict();
 jq(function () {
  alert(jQuery); //构造函数
 });
</script>

関連する推奨事項:

jquery ライブラリと他のライブラリ間の競合の問題を解決するには jquery.noConflict() を使用する

js/jQuery ライブラリの書き方 (経験の概要)

jQuery ライブラリ他の JS ライブラリと競合します Solution_jquery

以上がjQueryライブラリの競合についてどうするかの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
JavaScript in Action:実際の例とプロジェクトJavaScript in Action:実際の例とプロジェクトApr 19, 2025 am 12:13 AM

現実世界でのJavaScriptのアプリケーションには、フロントエンドとバックエンドの開発が含まれます。 1)DOM操作とイベント処理を含むTODOリストアプリケーションを構築して、フロントエンドアプリケーションを表示します。 2)node.jsを介してRestfulapiを構築し、バックエンドアプリケーションをデモンストレーションします。

JavaScriptとWeb:コア機能とユースケースJavaScriptとWeb:コア機能とユースケースApr 18, 2025 am 12:19 AM

Web開発におけるJavaScriptの主な用途には、クライアントの相互作用、フォーム検証、非同期通信が含まれます。 1)DOM操作による動的なコンテンツの更新とユーザーインタラクション。 2)ユーザーエクスペリエンスを改善するためにデータを提出する前に、クライアントの検証が実行されます。 3)サーバーとのリフレッシュレス通信は、AJAXテクノロジーを通じて達成されます。

JavaScriptエンジンの理解:実装の詳細JavaScriptエンジンの理解:実装の詳細Apr 17, 2025 am 12:05 AM

JavaScriptエンジンが内部的にどのように機能するかを理解することは、開発者にとってより効率的なコードの作成とパフォーマンスのボトルネックと最適化戦略の理解に役立つためです。 1)エンジンのワークフローには、3つの段階が含まれます。解析、コンパイル、実行。 2)実行プロセス中、エンジンはインラインキャッシュや非表示クラスなどの動的最適化を実行します。 3)ベストプラクティスには、グローバル変数の避け、ループの最適化、constとletsの使用、閉鎖の過度の使用の回避が含まれます。

Python vs. JavaScript:学習曲線と使いやすさPython vs. JavaScript:学習曲線と使いやすさApr 16, 2025 am 12:12 AM

Pythonは、スムーズな学習曲線と簡潔な構文を備えた初心者により適しています。 JavaScriptは、急な学習曲線と柔軟な構文を備えたフロントエンド開発に適しています。 1。Python構文は直感的で、データサイエンスやバックエンド開発に適しています。 2。JavaScriptは柔軟で、フロントエンドおよびサーバー側のプログラミングで広く使用されています。

Python vs. JavaScript:コミュニティ、ライブラリ、リソースPython vs. JavaScript:コミュニティ、ライブラリ、リソースApr 15, 2025 am 12:16 AM

PythonとJavaScriptには、コミュニティ、ライブラリ、リソースの観点から、独自の利点と短所があります。 1)Pythonコミュニティはフレンドリーで初心者に適していますが、フロントエンドの開発リソースはJavaScriptほど豊富ではありません。 2)Pythonはデータサイエンスおよび機械学習ライブラリで強力ですが、JavaScriptはフロントエンド開発ライブラリとフレームワークで優れています。 3)どちらも豊富な学習リソースを持っていますが、Pythonは公式文書から始めるのに適していますが、JavaScriptはMDNWebDocsにより優れています。選択は、プロジェクトのニーズと個人的な関心に基づいている必要があります。

C/CからJavaScriptへ:すべてがどのように機能するかC/CからJavaScriptへ:すべてがどのように機能するかApr 14, 2025 am 12:05 AM

C/CからJavaScriptへのシフトには、動的なタイピング、ゴミ収集、非同期プログラミングへの適応が必要です。 1)C/Cは、手動メモリ管理を必要とする静的に型付けられた言語であり、JavaScriptは動的に型付けされ、ごみ収集が自動的に処理されます。 2)C/Cはマシンコードにコンパイルする必要がありますが、JavaScriptは解釈言語です。 3)JavaScriptは、閉鎖、プロトタイプチェーン、約束などの概念を導入します。これにより、柔軟性と非同期プログラミング機能が向上します。

JavaScriptエンジン:実装の比較JavaScriptエンジン:実装の比較Apr 13, 2025 am 12:05 AM

さまざまなJavaScriptエンジンは、各エンジンの実装原則と最適化戦略が異なるため、JavaScriptコードを解析および実行するときに異なる効果をもたらします。 1。語彙分析:ソースコードを語彙ユニットに変換します。 2。文法分析:抽象的な構文ツリーを生成します。 3。最適化とコンパイル:JITコンパイラを介してマシンコードを生成します。 4。実行:マシンコードを実行します。 V8エンジンはインスタントコンピレーションと非表示クラスを通じて最適化され、Spidermonkeyはタイプ推論システムを使用して、同じコードで異なるパフォーマンスパフォーマンスをもたらします。

ブラウザを超えて:現実世界のJavaScriptブラウザを超えて:現実世界のJavaScriptApr 12, 2025 am 12:06 AM

現実世界におけるJavaScriptのアプリケーションには、サーバー側のプログラミング、モバイルアプリケーション開発、モノのインターネット制御が含まれます。 2。モバイルアプリケーションの開発は、ReactNativeを通じて実行され、クロスプラットフォームの展開をサポートします。 3.ハードウェアの相互作用に適したJohnny-Fiveライブラリを介したIoTデバイス制御に使用されます。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター