目次
1.基础版jQuery插件
2.满足链式调用的jQuery插件
3.防止$符号污染的jQuery插件
4.可以接受参数的jQuery插件
1. 基本的な jQuery プラグイン
2. チェーン呼び出しを満たす jQuery プラグイン
3. $ シンボル汚染を防ぐ jQuery プラグイン
4. パラメーターを受け入れることができる jQuery プラグイン
总结

JQueryプラグインを理解する方法

Sep 21, 2017 am 10:54 AM
jquery プラグイン 理解する

実際の開発作業では、スクロール、ページング、カレンダー、その他の表示効果などのビジネス ニーズが常に発生します。jQuery を使用したことがあり、jQuery の使用に精通している人向けです。 の場合、最初に思い浮かぶのは、対応する表示ニーズを満たす既存の jQuery プラグインを探すことです。現在、ページで一般的に使用される一部のコンポーネントには、さまざまな jQuery プラグインから選択できます。jQuery プラグインを特別に収集した Web サイトもインターネット上に多数あります。 jQuery プラグインを使用すると、確かに開発作業に利便性がもたらされますが、原理を理解せずに単純に使用するだけだと、使用中やプラグインのカスタマイズ中に問題が発生することがあります。開発中には多くの疑問が生じるでしょう。この記事の目的は、jQuery プラグインの開発原則を素早く理解し、jQuery 開発の基本スキルを習得することです。 jQuery以及熟悉jQuery使用的人来说,首先想到的肯定是寻找现有的jQuery插件来满足相应的展示需求。目前页面中常用的一些组件,都有多种jQuery插件可供选择,网络上也有很多专门收集jQuery插件的网站。利用jQuery插件确实可以给我们的开发工作带来便捷,但是如果只是会简单使用,而对其中的原理不甚了解,那么在使用过程中碰到问题或者对插件进行定制开发时就会有诸多疑惑。本文的目的就是可以快速了解jQuery插件的开发原理以及掌握jQuery开发的基本技能。


进行jQuery插件开发前,首先要知道两个问题:什么是jQuery插件?jQuery插件如何使用?
第一个问题,jQuery插件就是用来扩展jQuery原型对象的一个方法,简单来说就是jQuery插件是jQuery对象的一个方法。其实回答了第一个问题,也就知道第二个问题的答案了,jQuery插件的使用方式就是jQuery对象方法的调用。

我们先看个例子:$("a").css("color","red")。我们知道每个jQuery对象都会包含jQuery中定义的DOM操作方法,这里使用$方法来选择a元素,返回一个a元素的jQuery对象,这个对象就可以使用jQuery中定义的DOM操作方法。那么jQuery对象是如何获取这些方法的呢?其实jQuery内部定义了一个jQuery.fn对象,查看jQuery源码可以发现jQuery.fn=jQuery.prototype,也就是说jQuery.fn对象是jQuery的原型对象,jQueryDOM操作方法都在jQuery.fn对象上定义的,然后jQuery对象就可以通过原型继承这些方法。

1.基础版jQuery插件

知道了上面这些知识,我们就可以来写一个简单的jQuery插件。假如我现在需要一个jQuery插件用来改变标签内容颜色,就可以按下面的方式来实现这个插件:

$.fn.changeStyle = function(colorStr){
         this.css("color",colorStr);
}
ログイン後にコピー

然后按下面的方式来使用插件:

$("p").changeStyle("red");
ログイン後にコピー

插件调用的时候,插件内部的this就是当前调用插件的jQuery对象,这样的话每个使用$()方法选择的标签,在调用changeStyle()插件时都会使用css()方法重设color样式。

2.满足链式调用的jQuery插件

链式调用时jQuery的一大特色,一个通用的插件应该遵循jQuery风格,满足链式调用要求。实现链式调用的方式也很简单:

$.fn.changeStyle = function(colorStr){
         this.css("color",colorStr);         
         return this;
}
ログイン後にコピー

然后使用的时候就可以链式调用其他方法了:

$("p").changeStyle("red").addClass("red-color");
ログイン後にコピー

实现链式调用的关键点就一行代码return this,插件中加了这行代码,那么在插件执行完之后,就会把当前的jQuery对象返回,然后就可以在插件方法后面继续调用其它jQuery方法。

3.防止$符号污染的jQuery插件

有很多js库都会使用$符号,虽然jQuery可以使用jQuery.noConflict()方法交出$符号的使用权,但是如果定义插件的时候,使用$.fn对象来定义的,那么这些插件使用的时候就会受到其它使用$变量的js库的影响。对于这种情况,我们可以使用立即执行函数通过传参的方式封装插件。形式如下:

(function($){
     $.fn.changeStyle = function(colorStr){
         this.css("color",colorStr);        
         return this;
     }
}(jQuery));
ログイン後にコピー

因为使用了立即执行函数,所以此时的$只属于这个立即执行函数的函数作用域,这样就可以避免$符号的污染。

4.可以接受参数的jQuery插件

继续上面的例子,假如我还想为这个插件添加一个设置标签元素内容文字大小的功能,那么我可以这么来实现:

(function($){
     $.fn.changeStyle = function(colorStr,fontSize){
         this.css("color",colorStr).css("fontSize",fontSize+"px");        
         return this;
     }
}(jQuery));
ログイン後にコピー

上面这种插件传参方式适用于参数比较少的情况,如果需要传给插件内部的参数比较多,我们可以定义一个参数对象,然后把需要传给插件的参数放在参数对象中。插件定义时如下:

(function($){
     $.fn.changeStyle = function(option){
         this.css("color",option.colorStr).css("fontSize",option.fontSize+"px");        
         return this;
     }

}(jQuery));
ログイン後にコピー

使用方式:
$("p").changeStyle({colorStr:"red",fontSize:14});



jQuery プラグインを開発する前に、まず 2 つの質問について理解しておく必要があります。jQuery プラグインとは何ですか? jQueryプラグインの使い方は?

最初の質問、jQuery プラグインは、jQuery プロトタイプ オブジェクトを拡張するために使用されるメソッドです。簡単に言うと、jQuery< です。 /code> プラグインは、<code>jQuery オブジェクトのメソッドです。実際、最初の質問に答えると、jQuery プラグインを使用する方法は、jQuery オブジェクト メソッドを呼び出すことになります。 。 🎜🎜まず例を見てみましょう: $("a").css("color","re​​d")。各 jQuery オブジェクトには、jQuery で定義された DOM 操作メソッドが含まれることがわかっています。ここでは、$ メソッドを使用して要素を選択し、 jQuery オブジェクトを返す場合、このオブジェクトは jQuery で定義された DOM 操作メソッドを使用できます。では、jQuery オブジェクトはどのようにしてこれらのメソッドを取得するのでしょうか?実際、jQuery は内部で jQuery.fn オブジェクトを定義しています。jQuery ソース コードを見ると、jQuery.fn= が見つかります。 jQuery.prototype</code >、つまり、<code>jQuery.fn オブジェクトは jQuery のプロトタイプ オブジェクトであり、DOM オペレーションjQuery のメソッドはすべて jQuery.fn オブジェクトで定義されているため、jQuery オブジェクトはプロトタイプを通じてこれらのメソッドを継承できます。 🎜

1. 基本的な jQuery プラグイン

🎜 上記の知識があれば、簡単な jQuery プラグインを作成できます。ラベルのコンテンツの色を変更するために jQuery プラグインが必要な場合は、次の方法でプラグインを実装できます: 🎜
(function($){
     $.fn.changeStyle = function(option){
          var defaultSetting = { colorStr:"green",fontSize:12};
          var setting = $.extend(defaultSetting,option);
          this.css("color",setting.colorStr).css("fontSize",setting.fontSize+"px");        
         return this;
     }
}(jQuery));
ログイン後にコピー
ログイン後にコピー
🎜 次に、次の方法でプラグインを使用します。 : 🎜
//注意为了更好的兼容性,开始前有个分号;(function($){
     $.fn.extend({         
         changeStyle:function(option){             
         var defaultSetting = { colorStr:"green",fontSize:12};         
         var setting = $.extend(defaultSetting,option);         
         this.css("color",setting.colorStr).css("fontSize",setting.fontSize+"px");        
         return this; 
          }
     });
}(jQuery));//这里将Jquery作为实参传递给匿名函数
ログイン後にコピー
ログイン後にコピー
🎜プラグインが呼び出されます。このとき、プラグイン内の this は、現在プラグインを呼び出している jQuery オブジェクトです。この場合、 を使用して選択された各タグです。 <code>changeStyle()< /code> がプラグインされると、$() メソッドが呼び出されます。css() メソッドは、color</ をリセットするために使用されます。コード>スタイル。 🎜<h4 id="strong-チェーン呼び出しを満たす-jQuery-プラグイン-strong"><strong>2. チェーン呼び出しを満たす jQuery プラグイン</strong></h4>🎜 チェーン呼び出しは、<code>jQuery の主要な機能です。< code >jQuery スタイル。チェーン呼び出しの要件を満たします。チェーン呼び出しを実装する方法も非常に簡単です: 🎜rrreee🎜 そして、それを使用するときに、他のメソッドをチェーン呼び出しできます: 🎜rrreee🎜 チェーン呼び出しを実装するための重要なポイントは、コード return this</code の 1 行だけです。 >、プラグイン このコード行を追加すると、プラグインが実行された後、現在の <code>jQuery オブジェクトが返され、引き続き他の jQuery を呼び出すことができます。 > プラグイン メソッドの後のメソッド。 🎜

3. $ シンボル汚染を防ぐ jQuery プラグイン

🎜 jQuery とはいえ、<code>$ シンボルを使用する JS ライブラリは数多くあります。 jQuery.noConflict() メソッドを使用して、$ 記号を使用する権利を渡すことができますが、プラグインを定義する場合は、< code>$.fn オブジェクトが定義されている場合、これらのプラグインは、$ 変数を使用する他の js ライブラリの影響を受けます。この場合、即時実行関数を使用して、パラメーターを渡すことでプラグインをカプセル化できます。形式は以下の通りです。 🎜rrreee🎜即時実行関数を使用しているため、この時の$はこの即時実行関数の関数スコープのみに属し、$シンボルの汚染を避けられます。 🎜

4. パラメーターを受け入れることができる jQuery プラグイン

🎜 上の例を続けて、このプラグインにテキスト サイズを設定する関数も追加したい場合🎜rrreee🎜 上記のプラグイン パラメーター受け渡しメソッドは、より多くのパラメーターを渡す必要がある場合に適しています。プラグインでは、パラメーター オブジェクトを定義し、プラグインに渡す必要があるパラメーターをパラメーター オブジェクトに含めることができます。プラグインは次のように定義されます: 🎜rrreee🎜Usage: 🎜$("p").changeStyle({colorStr:"red",fontSize:14}); 🎜パラメータをプラグインのもう 1 つの利点は、プラグイン内のいくつかのパラメーターにいくつかのデフォルト値を定義できることです。例: 🎜
(function($){
     $.fn.changeStyle = function(option){
          var defaultSetting = { colorStr:"green",fontSize:12};
          var setting = $.extend(defaultSetting,option);
          this.css("color",setting.colorStr).css("fontSize",setting.fontSize+"px");        
         return this;
     }
}(jQuery));
ログイン後にコピー
ログイン後にコピー

上面的代码用到了$.extend方法,这个方法在这里的用法就是合并两个对象,即把后面一个对象的存在的属性值赋值给第一个对象,具体用法可以参考这里。$.extend方法还有一种作用是用来扩展jQuery对象本身。
这样定义的插件,我们在使用时如果不传fontSize,那么使用这个插件的jQuery对象标签的内容会被设置成默认的12px
使用方式:
$("p").changeStyle({colorStr:"red"});
注意:在为插件定义默认参数时,一定要把默认参数写在插件方法内部,这样默认参数的作用域就在插件内部。


总结

定义插件的方式除了上面说的用$.fn来定义,还有另外一种方式来定义插件,那就是使用$.fn.extend方法。类似下面的写法:

//注意为了更好的兼容性,开始前有个分号;(function($){
     $.fn.extend({         
         changeStyle:function(option){             
         var defaultSetting = { colorStr:"green",fontSize:12};         
         var setting = $.extend(defaultSetting,option);         
         this.css("color",setting.colorStr).css("fontSize",setting.fontSize+"px");        
         return this; 
          }
     });
}(jQuery));//这里将Jquery作为实参传递给匿名函数
ログイン後にコピー
ログイン後にコピー

PS: $.extend方法和$.fn.extend方法都可以用来扩展jQuery功能,通过阅读jQuery源码我们可以发现这两个方法的本质区别,那就是$.extend方法是在jQuery全局对象上扩展方法,$.fn.extend方法是在$选择符选择的jQuery对象上扩展方法。所以扩展jQuery的公共方法一般用$.extend方法,定义插件一般用$.fn.extend方法。

以上がJQueryプラグインを理解する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホット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ヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Chrome プラグイン拡張機能のインストール ディレクトリとは何ですか? Chrome プラグイン拡張機能のインストール ディレクトリとは何ですか? Mar 08, 2024 am 08:55 AM

Chrome プラグイン拡張機能のインストール ディレクトリとは何ですか?通常の状況では、Chrome プラグイン拡張機能のデフォルトのインストール ディレクトリは次のとおりです。 1. WindowsXP での Chrome プラグインのデフォルトのインストール ディレクトリの場所: C:\DocumentsandSettings\username\LocalSettings\ApplicationData\Google\Chrome\UserData\ Default\Extensions2. Windows7 の chrome プラグインのデフォルトのインストール ディレクトリの場所: C:\Users\username\AppData\Local\Google\Chrome\User

Edge ブラウザがこのプラグインをサポートしない理由に対する 3 つの解決策を共有します Edge ブラウザがこのプラグインをサポートしない理由に対する 3 つの解決策を共有します Mar 13, 2024 pm 04:34 PM

ユーザーが Edge ブラウザを使用する場合、より多くのニーズを満たすためにいくつかのプラグインを追加する場合があります。しかし、プラグインを追加すると、このプラグインはサポートされていないと表示されます。この問題を解決するにはどうすればよいですか?今日は編集者が 3 つの解決策を紹介しますので、ぜひ試してみてください。方法 1: 別のブラウザを使用してみてください。方法 2: ブラウザ上の Flash Player が古いか見つからないため、プラグインがサポートされていない可能性があり、公式 Web サイトから最新バージョンをダウンロードできます。方法3:「Ctrl+Shift+Delete」キーを同時に押します。 「データを消去」をクリックしてブラウザを再度開きます。

jQueryでPUTリクエストメソッドを使用するにはどうすればよいですか? jQueryでPUTリクエストメソッドを使用するにはどうすればよいですか? Feb 28, 2024 pm 03:12 PM

jQueryでPUTリクエストメソッドを使用するにはどうすればよいですか? jQuery で PUT リクエストを送信する方法は、他のタイプのリクエストを送信する方法と似ていますが、いくつかの詳細とパラメータ設定に注意する必要があります。 PUT リクエストは通常​​、データベース内のデータの更新やサーバー上のファイルの更新など、リソースを更新するために使用されます。以下は、jQuery の PUT リクエスト メソッドを使用した具体的なコード例です。まず、jQuery ライブラリ ファイルが含まれていることを確認してから、$.ajax({u

jQuery のヒント: ページ上のすべての a タグのテキストをすばやく変更する jQuery のヒント: ページ上のすべての a タグのテキストをすばやく変更する Feb 28, 2024 pm 09:06 PM

タイトル: jQuery ヒント: ページ上のすべての a タグのテキストをすばやく変更する Web 開発では、ページ上の要素を変更したり操作したりする必要がよくあります。 jQuery を使用する場合、ページ内のすべての a タグのテキスト コンテンツを一度に変更する必要がある場合があります。これにより、時間と労力を節約できます。以下では、jQuery を使用してページ上のすべての a タグのテキストをすばやく変更する方法と、具体的なコード例を紹介します。まず、jQuery ライブラリ ファイルを導入し、次のコードがページに導入されていることを確認する必要があります: &lt

jQuery を使用してすべての a タグのテキスト コンテンツを変更する jQuery を使用してすべての a タグのテキスト コンテンツを変更する Feb 28, 2024 pm 05:42 PM

タイトル: jQuery を使用して、すべての a タグのテキスト コンテンツを変更します。 jQuery は、DOM 操作を処理するために広く使用されている人気のある JavaScript ライブラリです。 Web 開発では、ページ上のリンク タグ (タグ) のテキスト コンテンツを変更する必要が生じることがよくあります。この記事では、この目標を達成するために jQuery を使用する方法を説明し、具体的なコード例を示します。まず、jQuery ライブラリをページに導入する必要があります。 HTML ファイルに次のコードを追加します。

Google Chromeプラグインのブロックを解除する方法 Google Chromeプラグインのブロックを解除する方法 Apr 01, 2024 pm 01:41 PM

Google Chrome プラグインのブロックを解除するにはどうすればよいですか? Google Chrome を使用する際、豊富な機能やサービスを提供し、作業効率を向上させるために、さまざまな便利なプラグインをインストールするユーザーは多いですが、一部のユーザーは、Google Chrome にプラグインをインストールすると、プラグインが機能しなくなるという意見を持っています。常に表示されます。がブロックされています。この状況が発生した後、どうすればプラグインのブロックを解除できますか?次に、エディターが Google Chrome のプラグインのブロックを解除する手順を説明します。必要な友達は、見に来てください。 Google Chrome でプラグインのブロックを解除する方法 ステップ 1. ブロックされたプロンプトが表示されたら、「コントロール バー」をクリックし、「ActiveX コントロールのインストール」を選択します。 2. 次に、ブラウザの「ツール」メニューを開き、「インターネット オプション」をクリックします。 3.

Google Chrome でアニメーション プラグインを実行できる仕組み Google Chrome でアニメーション プラグインを実行できる仕組み Mar 28, 2024 am 08:01 AM

Google Chrome ではどのようにしてアニメーション プラグインを実行できるようになりますか? Google Chrome は非常に強力です。多くの友人はビデオ アニメーションを見るためにこのブラウザを使用するのが好きです。ただし、さまざまなアニメーション ビデオを見たい場合は、ブラウザにアニメーション プラグインをインストールする必要があります。多くの友人は Google Chrome を使用しています。アニメーションプラグインを入れても動画が見れないのですが、どうすればいいでしょうか?次に、アニメーション プラグインを Google Chrome で実行できるようにするための具体的な手順をエディターに示します。興味のある友人は、見に来てください。 Google Chrome でアニメーション プラグインの実行を許可する具体的な手順: 1. まず、コンピュータで Google Chrome を実行し、ホームページの右上隅にあるメイン メニュー ボタンをクリックします (図を参照)。 2. メイン メニューを開いた後、下の「設定」オプションを選択します (図を参照)。 3. 設定で

jQuery 要素に特定の属性があるかどうかを確認するにはどうすればよいですか? jQuery 要素に特定の属性があるかどうかを確認するにはどうすればよいですか? Feb 29, 2024 am 09:03 AM

jQuery 要素に特定の属性があるかどうかを確認するにはどうすればよいですか? jQuery を使用して DOM 要素を操作する場合、要素に特定の属性があるかどうかを判断する必要がある状況がよく発生します。この場合、jQuery が提供するメソッドを使用してこの関数を簡単に実装できます。以下では、jQuery 要素が特定の属性を持つかどうかを判断するために一般的に使用される 2 つの方法を紹介し、具体的なコード例を添付します。方法 1: attr() メソッドと typeof 演算子 // を使用して、要素に特定の属性があるかどうかを判断します

See all articles