Angular ライフサイクル フックは、開発者が Angular コンポーネントの作成から破棄 (初期化、変更、破棄を含む) までのライフ サイクルの重要な瞬間を利用できるようにするメソッドです。最も一般的に使用されるライフサイクル フックは次のとおりです:
- Constructor: ページが初めて読み込まれるときに呼び出されます。呼び出しは 1 回だけです。
- ngOnChanges: 複数回実行します。初回は、コンポーネントが作成/ロードされたときに実行されます。このフックが呼び出されるたびに @input デコレータを使用してカスタム プロパティに変更がある場合。引数を使用して動作しました - 単純な変更
- ngOnInit: コンポーネントが初期化されると呼び出されます。コンポーネントの状態を設定するのに最適です。
- ngDoCheck: 変更を手動で検出するために使用されます (変更検出サイクルごとに呼び出されます)。
- ngAfterContentInit: コンテンツがコンポーネントに投影された後に呼び出されます。
- ngAfterContentChecked: 投影されたコンテンツがチェックされた後に呼び出されます。
- ngAfterViewInit: ビューが初期化された後に呼び出されます。
- ngAfterViewChecked: Angular がコンポーネントのビューをチェックした後に呼び出されます。
- ngOnDestroy: コンポーネントが破棄される直前に呼び出されます。これを使用して、observable からのサブスクライブ解除など、リソースをクリーンアップします。
本題に入る前に、前提条件となるプロジェクトを作成しましょう:
親コンポーネントと子コンポーネントが必要になります。親コンポーネントに入力フィールドがあり、その入力値を子に渡して子コンポーネントに表示します。
parent.component.ts
import { Component, OnInit } from '@angular/core'; @Component({ selector: 'app-parent', templateUrl: './parent.component.html', styleUrls: ['./parent.component.css'] }) export class ParentComponent implements OnInit { constructor() { } ngOnInit(): void { } value:string = ''; SubmitValue(val: any) { this.value = val.value; } }
parent.component.html
<h1 id="Lifecycle-Hooks">Lifecycle Hooks</h1> <input type="text" placeholder="Input here..."> <button>Submit Value</button> <br><br> <app-child></app-child>
child.component.ts
import { Component, Input, OnInit } from '@angular/core'; @Component({ selector: 'app-child', templateUrl: './child.component.html', styleUrls: ['./child.component.css'] }) export class ChildComponent implements OnInit { constructor() { } @Input() inputValue: string = "LifeCycle Hooks"; ngOnInit(): void { } }
child.component.html
<div> Input Value: <strong>{{inputValue}}</strong> </div>
次のような出力が得られます:
1.コンストラクター
- コンストラクターは、コンポーネントを初期化するために使用される TypeScript クラス メソッドです。これは、Angular ライフサイクル フックの前に呼び出されます。
- 主な用途: 依存関係の注入を初期化し、変数を設定します。
export class ChildComponent implements OnInit { constructor() { **console.log("Constructor Called");** } @Input() inputValue: string = "LifeCycle Hooks"; ngOnInit(): void {} }
2.ngOnChanges
- コンポーネントの入力プロパティが変更されたときに呼び出されます。
- 入力プロパティの以前の値と現在の値を含む SimpleChanges オブジェクトを提供します。
- 使用法: 親コンポーネントからデータ入力プロパティを更新して、このフックをトリガーします。
import { Component, OnInit } from '@angular/core'; @Component({ selector: 'app-parent', templateUrl: './parent.component.html', styleUrls: ['./parent.component.css'] }) export class ParentComponent implements OnInit { constructor() { } ngOnInit(): void { } value:string = ''; SubmitValue(val: any) { this.value = val.value; } }
再度値を入力し、ngOnChanges を再度呼び出しましたが、コンストラクターは 1 回しか呼び出されませんでした。
変更引数の内容を見てみましょう:
<h1 id="Lifecycle-Hooks">Lifecycle Hooks</h1> <input type="text" placeholder="Input here..."> <button>Submit Value</button> <br><br> <app-child></app-child>
値を入力して見てみましょう:
3.ngOnInit
- 最初の ngOnChanges の後に 1 回呼び出されます。
- 主な用途: コンポーネントを初期化し、レンダリングに必要なデータを設定します。
import { Component, Input, OnInit } from '@angular/core'; @Component({ selector: 'app-child', templateUrl: './child.component.html', styleUrls: ['./child.component.css'] }) export class ChildComponent implements OnInit { constructor() { } @Input() inputValue: string = "LifeCycle Hooks"; ngOnInit(): void { } }
4.ngDoCheck
- Angular がコンポーネントまたはその子の変更を検出するたびに実行されます。
- これをカスタム変更検出ロジックに使用します。
<div> Input Value: <strong>{{inputValue}}</strong> </div>
5.ngAfterContentInit
- コンテンツ (例:
) がコンポーネントに投影された後に 1 回呼び出されます。
child.component.html
export class ChildComponent implements OnInit { constructor() { **console.log("Constructor Called");** } @Input() inputValue: string = "LifeCycle Hooks"; ngOnInit(): void {} }
parent.component.html
export class ChildComponent implements OnInit, OnChanges { constructor() { console.log("Constructor Called"); } ngOnChanges(changes: SimpleChanges): void { console.log("ngOnChanges Called"); } @Input() inputValue: string = "LifeCycle Hooks"; ngOnInit(): void {} }
child.component.ts
ngOnChanges(changes: SimpleChanges): void { console.log("ngOnChanges Called", changes); }
6.ngAfterContentChecked
- 投影されたコンテンツをチェックするたびに呼び出されます。
- パフォーマンスの問題を避けるために、使用は控えめにしてください。
export class ChildComponent implements OnInit, OnChanges { constructor() { console.log("Constructor Called"); } ngOnChanges(changes: SimpleChanges): void { console.log("ngOnChanges Called"); } @Input() inputValue: string = "LifeCycle Hooks"; ngOnInit(): void { console.log("ngOnInit Called"); } }
これについて遊んでみましょう:
export class ChildComponent implements OnInit, OnChanges, DoCheck { constructor() { console.log("Constructor Called"); } ngOnChanges(changes: SimpleChanges): void { console.log("ngOnChanges Called", changes); } @Input() inputValue: string = "LifeCycle Hooks"; ngOnInit(): void { console.log("ngOnInit Called"); } ngDoCheck() { console.log("ngDoCheck Called"); } }
ng-content に再び変更があると、ngAfterContentChecked が呼び出されます。
7.ngAfterViewInit
- コンポーネントのビューとその子ビューが初期化された後に 1 回呼び出されます。
- サードパーティのライブラリまたは DOM 操作の初期化に役立ちます。
8.ngAfterViewChecked
- コンポーネントのビューとその子ビューをチェックするたびに呼び出されます。
9.ngOnDestroy
- コンポーネントが破棄される直前に呼び出されます。
- Observables からのサブスクライブ解除やイベント リスナーの切り離しなどのクリーンアップ タスクに使用します。
ngOnDestroy はコンポーネントを破棄する場合にのみ呼び出されます。そのため、コンポーネントの破棄ボタンをクリックしたときに子コンポーネントを削除してみます。
手配をしましょう:
parent.component.ts
import { Component, OnInit } from '@angular/core'; @Component({ selector: 'app-parent', templateUrl: './parent.component.html', styleUrls: ['./parent.component.css'] }) export class ParentComponent implements OnInit { constructor() { } ngOnInit(): void { } value:string = ''; SubmitValue(val: any) { this.value = val.value; } }
parent.component.html
<h1 id="Lifecycle-Hooks">Lifecycle Hooks</h1> <input type="text" placeholder="Input here..."> <button>Submit Value</button> <br><br> <app-child></app-child>
「コンポーネントを破棄」ボタンをクリックする前に:
「コンポーネントを破棄」ボタンをクリックした後:
ライフサイクルフックシーケンス:
- コンストラクター
- ngOnChanges (@Input プロパティが存在する場合)
- ngOnInit
- ngDoCheck
- ngAfterContentInit
- ngAfterContentChecked
- ngAfterViewInit
- ngAfterViewChecked
- ngOnDestroy
これらのフックを理解し、効果的に使用することで、ライフサイクルのさまざまな段階でコンポーネントの動作を管理できます。
以上がAngular のコンポーネントのライフサイクルの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

JavaScript文字列置換法とFAQの詳細な説明 この記事では、javaScriptの文字列文字を置き換える2つの方法について説明します:内部JavaScriptコードとWebページの内部HTML。 JavaScriptコード内の文字列を交換します 最も直接的な方法は、置換()メソッドを使用することです。 str = str.replace( "find"、 "置換"); この方法は、最初の一致のみを置き換えます。すべての一致を置き換えるには、正規表現を使用して、グローバルフラグGを追加します。 str = str.replace(/fi

楽なWebページレイアウトのためにjQueryを活用する:8本質的なプラグイン jQueryは、Webページのレイアウトを大幅に簡素化します。 この記事では、プロセスを合理化する8つの強力なjQueryプラグイン、特に手動のウェブサイトの作成に役立ちます

それで、あなたはここで、Ajaxと呼ばれるこのことについてすべてを学ぶ準備ができています。しかし、それは正確には何ですか? Ajaxという用語は、動的でインタラクティブなWebコンテンツを作成するために使用されるテクノロジーのゆるいグループ化を指します。 Ajaxという用語は、もともとJesse Jによって造られました

記事では、JavaScriptライブラリの作成、公開、および維持について説明し、計画、開発、テスト、ドキュメント、およびプロモーション戦略に焦点を当てています。

このチュートリアルでは、Ajaxを介してロードされた動的なページボックスの作成を示しており、フルページのリロードなしでインスタントリフレッシュを可能にします。 JQueryとJavaScriptを活用します。カスタムのFacebookスタイルのコンテンツボックスローダーと考えてください。 重要な概念: ajaxとjquery

10の楽しいjQueryゲームプラグインして、あなたのウェブサイトをより魅力的にし、ユーザーの粘着性を高めます! Flashは依然としてカジュアルなWebゲームを開発するのに最適なソフトウェアですが、jQueryは驚くべき効果を生み出すこともできます。また、純粋なアクションフラッシュゲームに匹敵するものではありませんが、場合によってはブラウザで予期せぬ楽しみもできます。 jquery tic toeゲーム ゲームプログラミングの「Hello World」には、JQueryバージョンがあります。 ソースコード jQueryクレイジーワードコンポジションゲーム これは空白のゲームであり、単語の文脈を知らないために奇妙な結果を生み出すことができます。 ソースコード jquery鉱山の掃引ゲーム

このJavaScriptライブラリは、Cookieに依存せずにセッションデータを管理するためにWindow.nameプロパティを活用します。 ブラウザ全体でセッション変数を保存および取得するための堅牢なソリューションを提供します。 ライブラリは、セッションの3つのコア方法を提供します

このチュートリアルでは、jQueryを使用して魅惑的な視差の背景効果を作成する方法を示しています。 見事な視覚的な深さを作成するレイヤー画像を備えたヘッダーバナーを構築します。 更新されたプラグインは、jQuery 1.6.4以降で動作します。 ダウンロードしてください


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

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

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

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

ホットトピック









