ホームページ >ウェブフロントエンド >jsチュートリアル >jqueryプラグインのconflict_javascriptスキルの問題を解決する
今日は、jquery と jquery プラグイン ライトボックスを使用して、画像の浮動拡大効果を問題なく作成するサンプルを作成しました。
次に、ナビゲーション バーの js を追加しました。構造ナビゲーションの js と画像のフローティングと拡大の js が競合しました。
ナビゲーションバー js のみが有効であるか、イメージフローティング js のみが有効です。
ネットで検索した結果、解決策は次のとおりです
jQuery.noConflict()
概要
この関数を実行して、変数 $ の制御を最初のライブラリに移して実装します。
これは、jQuery が他のライブラリの $object と競合しないようにするのに役立ちます。
この関数を実行した後は、jQuery 変数を使用してのみ jQuery オブジェクトにアクセスできます。たとえば、$("div p") が使用されている場合は、jQuery("div p") に置き換える必要があります。
'''注:''''この関数は、jQuery ファイルをインポートした後、および別のライブラリをインポートする前に使用する必要があります''''。競合が発生する可能性があります。もちろん、jQuery が最後にインポートされたものでない限り、他の競合するライブラリが使用される前にも実行する必要があります。例
説明:
$ で参照されるオブジェクトを元のオブジェクトにマップします。
jQuery コード:
jQuery.noConflict();
// jQuery を使用
jQuery("div p").hide();
// 他のものを使用ライブラリの $()
$("content").style.display = 'none';
説明:
エイリアス $ の使用を復元し、この関数のスコープ内で $ を jQuery のエイリアスとして引き続き使用する関数を作成して実行します。 。この関数では、元の $ オブジェクトは無効です。この関数は、他のライブラリに依存しないほとんどのプラグインで適切に機能します。
jQuery コード:
jQuery.noConflict();
(function($) {
$(function() {
// $ を jQuery エイリアス コードとして使用します
});
})(jQuery);
// $ をエイリアスとして使用する他のライブラリのコード説明:
次のライブラリ オブジェクトで jQuery を使用するための新しいエイリアスを作成します。
jQuery コード:
var j = jQuery.noConflict();
// jQuery ベースのコード
j("div p").hide();
//他のライブラリに基づく $() コード
$("content").style.display = 'none';
jQuery.noConflict();
(function($) {
$(function() {
// $ を jQuery エイリアスとして使用するコード ナビゲーション js を置きます真ん中のコードを書くだけです
});
})(jQuery);
// $ をエイリアスとして使用する他のライブラリのコード