目次
" >カスタム フォーム コントロールを実装する方法
" >ControlValueAccessor の使用方法
ホームページ ウェブフロントエンド jsチュートリアル Angular による ControlValueAccessor を使用してカスタム フォーム コントロールを実装する方法の詳細な説明

Angular による ControlValueAccessor を使用してカスタム フォーム コントロールを実装する方法の詳細な説明

Apr 28, 2021 am 09:34 AM
angular controlvalueaccessor

この記事では、AngularControlValueAccessor を使用してカスタム フォーム コントロールを実装する方法を紹介します。一定の参考値があるので、困っている友達が参考になれば幸いです。

Angular による ControlValueAccessor を使用してカスタム フォーム コントロールを実装する方法の詳細な説明

#Angular: [ControlValueAccessor] カスタム フォーム コントロール


実際の開発では、通常、さまざまなカスタマイズされた関数に遭遇します。 , 一部のコンポーネントは Angular フォームと対話しますが、このとき通常は外部から FormGroup オブジェクトを渡し、対応するロジックをコンポーネント内に記述して Angular フォームを操作します。フォーム内の 1 つの項目だけをカスタマイズする場合、フォーム オブジェクト全体を渡すのは明らかに不適切であり、コンポーネントも肥大化して表示されます。


<form [formGroup]="simpleForm">                                <br/>  <other-component [form]="simpleForm"></other-component>        <br/></form><br/>
ログイン後にコピー

では、これらのカスタム コンポーネントをネイティブ フォームのように使用できるでしょうか?現在、オープン ソース コンポーネントの ng-zorro-antd フォーム コンポーネントでは、ネイティブ フォームと同じように formControlName 属性を使用できます。このタイプのコンポーネントはカスタム フォーム コンポーネントと呼ばれます。 [関連する推奨事項: "

angular チュートリアル "]

カスタム フォーム コントロールを実装する方法

Angular では、ControlValueAccessor を使用します。コンポーネントを外側のラップされたフォームに関連付けることができます。

ControlValueAccessor は、次の処理を行うためのインターフェイスです。

    フォーム モデルからビュー/DOM への値の書き込み
  • ビュー/DOM が変更されたときに他のユーザーに通知する フォーム命令とコントロール

ControlValueAccessor

ControlValueAccessor インターフェイスは 4 つのメソッドを定義します。

writeValue(obj: any): void<br/><br/>registerOnChange(fn: any): void<br/><br/>registerOnTouched(fn: any): void<br/><br/>setDisabledState(isDisabled: boolean)?: void<br/>
ログイン後にコピー

writeValue(obj: any) : フォーム モデルの新しい値をビューまたは DOM プロパティ (必要な場合) に書き込むメソッド。これにより、外部から内部データ モデルにデータが書き込まれます。データ フローの方向: フォーム モデル -> コンポーネント。

registerOnChange(fn: any): ビュー内の何かが変更されたときに呼び出されるハンドラーを登録する方法。他のフォーム ディレクティブやフォーム コントロールに値を更新するように指示する機能があります。通常、イベントトリガ関数は registerOnChange に保存する必要がありますが、データが変更された場合、イベントトリガ関数を呼び出すことで外部データに変更を通知し、変更されたデータをパラメータとして渡すことができます。データ フローの方向: コンポーネント -> フォーム モデル。

registerOnTouched(fn: any): onTouched イベントを登録します。基本的に registerOnChange と同じですが、この関数は、フォーム コンポーネントがタッチ状態にあることを通知し、フォーム コンポーネントを変更するために使用される点が異なります。バインドされた FormControl の内部状態。ステータス変更: コンポーネント -> フォーム モデル。

setDisabledState(isDisabled: boolean): FormControl 状態変更 API が呼び出され、フォーム状態が Disabled に変更されると、setDisabledState() メソッドが呼び出され、カスタム フォーム コンポーネントに通知されます。現在のフォームの読み取りステータス、書き込みステータス。ステータス変更: フォームモデル -> コンポーネント。

ControlValueAccessor の使用方法

コントロール フレームワークを構築する

@Component({<br/>  selector: &#39;app-test-control-value-accessor&#39;,<br/>  templateUrl: &#39;./test-control-value-accessor.component.html&#39;,<br/>  providers: [{<br/>    provide: NG_VALUE_ACCESSOR,<br/>    useExisting: forwardRef(() => TestControlValueAccessorComponent),<br/>    multi: true<br/>  }]<br/>})<br/>export class TestControlValueAccessorComponent implements ControlValueAccessor {<br/><br/>  _counterValue = 0;<br/> <br/>  private onChange = (_: any) => {};<br/><br/>  constructor() { }<br/><br/>  get counterValue() {<br/>    return this._counterValue;<br/>  }<br/><br/>  set counterValue(value) {<br/>    this._counterValue = value;<br/>    // 触发 onChange,component 内部的值同步到 form model<br/>    this.onChange(this._counterValue);<br/>  }<br/><br/>  increment() {<br/>    this.counterValue++;<br/>  }<br/><br/>  decrement() {<br/>    this.counterValue--;<br/>  }<br/><br/>  // form model 的值同步到 component 内部<br/>  writeValue(obj: any): void {<br/>    if (obj !== undefined) {<br/>      this.counterValue = obj;<br/>    }<br/>  }<br/><br/>  registerOnChange(fn: any): void {<br/>    this.onChange = fn;<br/>  }<br/><br/>  registerOnTouched(fn: any): void { }<br/><br/>  setDisabledState?(isDisabled: boolean): void { }<br/><br/>}<br/>
ログイン後にコピー

ControlValueAccessor を登録する

フォーム コントロールの

ControlValueAccessor を取得するために、Angular は NG_VALUE_ACCESSOR トークンに登録されているすべての値を内部的に挿入します。コントロール自体を DI フレームは、フォームがその値にアクセスできるようにするコントロールになります。したがって、必要なのは、NG_VALUE_ACCESSOR 独自の値アクセサー インスタンス (コンポーネント) を使用してマルチプロバイダーを拡張することだけです。したがって、multi: true を設定すると、この token に対応するクラスが多数存在し、あちこちに散在していることを宣言することになります。

ここでは、

useExisting を使用する必要があります。これは、TestControlValueAccessorComponent が、それを使用するコンポーネントのディレクティブ依存関係として作成される可能性があるためです。これには、forwardRef の使用が必要です。この関数を使用すると、未定義のオブジェクトを参照できます。

@Component({<br/>  ...<br/>  providers: [<br/>    { <br/>      provide: NG_VALUE_ACCESSOR,<br/>      useExisting: forwardRef(() => TestControlValueAccessorComponent ),<br/>      multi: true<br/>    }<br/>  ]<br/>})<br/>export class TestControlValueAccessorComponent implements ControlValueAccessor {<br/>  ...<br/>}<br/>
ログイン後にコピー

コントロール インターフェイス

    test-control-value-accessor.component.html
  • <div class="panel panel-primary"><br/>  <div class="panel-heading">自定义控件</div><br/>  <div class="panel-body"><br/>    <button (click)="increment()">+</button><br/>    {{counterValue}}<br/>    <button (click)="decrement()">-</button><br/>  </div><br/></div><br/>
    ログイン後にコピー

フォーム

    app.component.html
  • <div class="constainer"><br/>  <form #form="ngForm"><br/>    <app-test-control-value-accessor name="message" [(ngModel)]="message"></app-test-control-value-accessor><br/>    <button type="button" (click)="submit(form.value)">Submit</button><br/>  </form><br/>  <pre class="brush:php;toolbar:false">{{ message }}


    ログイン後にコピー
    app.component.ts
  • @Component({<br/>  selector: &#39;app-root&#39;,<br/>  templateUrl: &#39;./app.component.html&#39;,<br/>  styleUrls: [&#39;./app.component.css&#39;]<br/>})<br/>export class AppComponent {<br/><br/>  message = 5;<br/><br/>  submit(value: any): void {<br/>    console.log(value);<br/>  }<br/><br/>}<br/>
    ログイン後にコピー

    を使用します。 参考

    • https://blog.thoughtram.io/angular/2016/07/27/custom-form-controls-in-angular- 2.html

    • https://almerosteyn.com/2016/04/linkup-custom-control-to-ngcontrol-ngmodel

    • https://juejin.im/post/597176886fb9a06ba4746d15

    • https://github.com/shhdgit/blogs/issues/11

    プログラミング関連の知識について詳しくは、プログラミング ビデオをご覧ください。 !

    以上がAngular による ControlValueAccessor を使用してカスタム フォーム コントロールを実装する方法の詳細な説明の詳細内容です。詳細については、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衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

Angular のメタデータとデコレータについて話しましょう Angular のメタデータとデコレータについて話しましょう Feb 28, 2022 am 11:10 AM

この記事では、Angular の学習を継続し、Angular のメタデータとデコレータを理解し、それらの使用法を簡単に理解します。

Ubuntu 24.04 に Angular をインストールする方法 Ubuntu 24.04 に Angular をインストールする方法 Mar 23, 2024 pm 12:20 PM

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

Angular で Monaco エディターを使用する方法の簡単な分析 Angular で Monaco エディターを使用する方法の簡単な分析 Oct 17, 2022 pm 08:04 PM

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

Angular のサーバーサイド レンダリング (SSR) について説明する記事 Angular のサーバーサイド レンダリング (SSR) について説明する記事 Dec 27, 2022 pm 07:24 PM

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

Angular + NG-ZORRO でバックエンド システムを迅速に開発 Angular + NG-ZORRO でバックエンド システムを迅速に開発 Apr 21, 2022 am 10:45 AM

この記事では、Angular の実践的な経験を共有し、angualr と ng-zorro を組み合わせてバックエンド システムを迅速に開発する方法を学びます。

フロントエンド開発に PHP と Angular を使用する方法 フロントエンド開発に PHP と Angular を使用する方法 May 11, 2023 pm 04:04 PM

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

Angular Learning State Manager NgRx の詳細な説明 Angular Learning State Manager NgRx の詳細な説明 May 25, 2022 am 11:01 AM

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

Angular と Node を使用したトークンベースの認証 Angular と Node を使用したトークンベースの認証 Sep 01, 2023 pm 02:01 PM

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

See all articles