Angular の HostBinding および HostListener デコレータの詳細
この記事では、Angular-HostBinding と HostListener の 2 つのデコレーターについて説明し、これら 2 つのデコレーターの使用シナリオを紹介します。
私の疑問
Angular を独学で学習しているときに、この 2 つのデコレータに遭遇した人がいるかどうかはわかりません。 ——HostBinding
および HostListener
。公式サイトでこの 2 つのデコレーターの API の説明を読んだとき、単語はすべて理解できるのに、それらがつながっていると理解できなくなり、非常に戸惑いました。さらに、公式 Web サイトに示されている例も非常にわかりにくく、これら 2 つの API の使用シナリオがわかりにくくなっています。 [推奨関連チュートリアル: "angular チュートリアル"]
公式 Web サイトの説明
まず、これら 2 つの API の説明を見てみましょう。公式 Web サイト:
HostBinding
(公式 Web サイトのリンク ):
は、DOM 属性をバインドされたプロパティとしてマークするために使用されます。ホストに接続し、構成メタデータを提供します。 Angular は、変更検出中にホスト プロパティのバインディングを自動的にチェックし、バインディングが変更された場合は、ディレクティブが配置されているホスト要素を更新します。
HostListener
(公式 Web サイトのリンク ):
は、リッスンして提供する DOM イベントを宣言するために使用されます。イベント内の情報 これが発生したときに実行するハンドラー メソッド。
これを読んだ後、この 2 人の兄弟の使用シナリオがどのようなものであるかわかりませんか?私の意見では、これら 2 つのデコレータの機能は、複雑な DOM 操作を 1 つの命令に抽出してコードを合理化することを容易にする です。あまりナンセンスではありませんが、コードを読むだけで一目で理解できます。
コード例
現時点でビジネス シナリオがあるとします。入力ボックスinput があり、入力するたびに色が表示されます。文字数と枠線の色が変わるので「レインボー入力ボックス」と名付けました。
@Component({ selector: 'app-rainbow-input-demo', template: ` <h3 id="这是一个彩虹输入框-每输入一次都会改变颜色">这是一个彩虹输入框,每输入一次都会改变颜色</h3> <input [class]="'my-input'" type="text" [style]="inputStyleObj" (keydown)="onKeyDown()" /> `, styles:[ `.my-input { border:none; outline: none; border: 2px solid #333333; border-radius: 5px; }` ] }) export class RainbowInputDemoComponent { //默认的颜色样式 public inputStyleObj = { color:null, borderColor:null, }; //颜色库 public possibleColors = [ 'darksalmon', 'hotpink', 'lightskyblue', 'goldenrod', 'peachpuff', 'mediumspringgreen', 'cornflowerblue', 'blanchedalmond', 'lightslategrey' ]; //键盘落下事件 onKeyDown(){ const index = Math.floor(Math.random() * this.possibleColors.length); //如果我们直接使用this.inputStyleObj.color = this.possibleColors[index]的话, //this.inputStyleObj虽然内容变了,由于它是引用类型,其地址值没有变。所以不会触发视图的重新渲染 //在angular中,和react似的,我们直接修改引用类型不会触发重新渲染,只能覆盖它或者合并它,使其地址值发生改变,才会触发重新渲染 //如果觉得麻烦的话,完全可以在模板中使用[style.color]和[style.borderColor] this.inputStyleObj = { color:this.possibleColors[index], borderColor:this.possibleColors[index], } } }
rainbowInput を他のコンポーネントで使用する必要がある場合はどうすればよいでしょうか?使用するたびにこれらのコードをコピーして貼り付ける必要がありますか?これは明らかにコンポーネントのカプセル化の原則に準拠していません。本当にこれを行うと、技術マネージャーやプロジェクト マネージャーもびっくりするでしょう。
@Directive({ selector: '[appRainbow]' }) export class RainbowInputDirective { public possibleColors = [ 'darksalmon', 'hotpink', 'lightskyblue', 'goldenrod', 'peachpuff', 'mediumspringgreen', 'cornflowerblue', 'blanchedalmond', 'lightslategrey' ]; //字体颜色 @HostBinding('style.color') color: string; //边框颜色 @HostBinding('style.borderColor') borderColor: string; //监听键盘落下的事件 @HostListener('keydown') onKeyDown() { //获取一个随机的颜色 const index = Math.floor(Math.random() * this.possibleColors.length); this.color = this.borderColor = this.possibleColors[index]; } } @Component({ selector: 'app-rainbow-input-demo', template: ` <h3 id="这是一个彩虹输入框-每输入一次都会改变颜色">这是一个彩虹输入框,每输入一次都会改变颜色</h3> <input [class]="'my-input'" type="text" appRainbow /> `, styles:[ //省略,和上面相同 ] }) export class RainbowInputDemoComponent {}
結論
コードでは、@HostBinding の機能が実際には特定の属性をホスト要素にバインドすることであることがわかりますが、このattribute単なる 属性 ではありません。この属性は、Angular テンプレートでサポートされている属性を指します。実際、@HostBinding は、テンプレートの [] または
bind- と同等です。同様に、@HostListener は、テンプレート内の
() または
on- と同等です。これにより、命令内のホスト要素に属性とメソッドをバインドできるようになります。達成される効果は、
(keydow) と
[style] を最初に直接記述した場合と同じです。テンプレート上で。したがって、これら 2 つのデコレータの文字列を無造作に記述することはできません。
命令とコンポーネントについて
ただし、実際には、Angular ではコンポーネントと命令の違いはそれほど大きくありません。これは、Angular のコンポーネント デコレータ @Component が次のとおりであるためです。 @ディレクティブから継承されます。 実際、この DOM 操作をコンポーネントにカプセル化することは不可能ではありません。コードは次のとおりです@Component({ selector:'input[appRainbow]' })
ええー
。概要
@HostBinding は、テンプレート @HostListener は、テンプレートの() または
on- と同等です。
プログラミング関連の知識について詳しくは、
プログラミング教育をご覧ください。 !
以上がAngular の HostBinding および HostListener デコレータの詳細の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック











Angular.js は、動的アプリケーションを作成するための無料でアクセスできる JavaScript プラットフォームです。 HTML の構文をテンプレート言語として拡張することで、アプリケーションのさまざまな側面を迅速かつ明確に表現できます。 Angular.js は、コードの作成、更新、テストに役立つさまざまなツールを提供します。さらに、ルーティングやフォーム管理などの多くの機能も提供します。このガイドでは、Ubuntu24 に Angular をインストールする方法について説明します。まず、Node.js をインストールする必要があります。 Node.js は、ChromeV8 エンジンに基づく JavaScript 実行環境で、サーバー側で JavaScript コードを実行できます。ウブにいるために

Angular Universal をご存知ですか?これは、Web サイトがより優れた SEO サポートを提供するのに役立ちます。

Angularでモナコエディタを使用するにはどうすればよいですか?以下の記事は、最近業務で使用したangularでのmonaco-editorの使い方を記録したものですので、皆様のお役に立てれば幸いです。

この記事では、Angular のステートマネージャー NgRx について深く理解し、NgRx の使用方法を紹介します。

インターネットの急速な発展に伴い、フロントエンド開発テクノロジーも常に改善され、反復されています。 PHP と Angular は、フロントエンド開発で広く使用されている 2 つのテクノロジーです。 PHP は、フォームの処理、動的ページの生成、アクセス許可の管理などのタスクを処理できるサーバー側スクリプト言語です。 Angular は、単一ページ アプリケーションの開発やコンポーネント化された Web アプリケーションの構築に使用できる JavaScript フレームワークです。この記事では、PHPとAngularをフロントエンド開発に使用する方法と、それらを組み合わせる方法を紹介します。

認証は、Web アプリケーションの最も重要な部分の 1 つです。このチュートリアルでは、トークンベースの認証システムと、それが従来のログイン システムとどのように異なるかについて説明します。このチュートリアルを終えると、Angular と Node.js で書かれた完全に動作するデモが表示されます。従来の認証システム トークンベースの認証システムに進む前に、従来の認証システムを見てみましょう。ユーザーはログイン フォームにユーザー名とパスワードを入力し、[ログイン] をクリックします。リクエストを行った後、データベースにクエリを実行してバックエンドでユーザーを認証します。リクエストが有効な場合、データベースから取得したユーザー情報を使用してセッションが作成され、セッション情報が応答ヘッダーで返され、セッション ID がブラウザに保存されます。対象となるアプリケーションへのアクセスを提供します。

Angular プロジェクトが大きすぎます。適切に分割するにはどうすればよいですか?次の記事では、Angular プロジェクトを合理的に分割する方法を紹介します。

この記事では、Angular の独立コンポーネント、Angular で独立コンポーネントを作成する方法、および既存のモジュールを独立コンポーネントにインポートする方法について説明します。
