ホームページ >ウェブフロントエンド >jsチュートリアル >Angular のテンプレートでメソッドを呼び出さないのはなぜですか

Angular のテンプレートでメソッドを呼び出さないのはなぜですか

青灯夜游
青灯夜游転載
2021-09-30 10:36:471997ブラウズ

この記事では、Angularのテンプレート(テンプレート)でメソッドが呼び出されない原因とその解決策をご紹介しますので、皆様のお役に立てれば幸いです。

Angular のテンプレートでメソッドを呼び出さないのはなぜですか

ng 生成コンポーネント コマンドを実行した後に Angular コンポーネントを作成すると、デフォルトで 4 つのファイルが生成されます:

  • コンポーネント ファイル <component-name>.component.ts</component-name>
  • テンプレート ファイル <component-name>.component.html</component-name>
  • CSS ファイル、<component-name>.component.css</component-name>
  • テスト ファイル <component-name>.component.spec。 ts</component-name>

[関連チュートリアルの推奨事項: "angular チュートリアル"]

テンプレートは HTML コードです。非イベントの呼び出しを避ける必要があります。それクラスのメソッド。例:

<!--html 模板-->
<p>
  translate Name: {{ originName }}
</p>
<p>
  translate Name: {{ getTranslatedName(&#39;你好&#39;) }}
</p>
<button (click)="onClick()">Click Me!</button>
// 组件文件
import { Component } from &#39;@angular/core&#39;;

@Component({
  selector: &#39;my-app&#39;,
  templateUrl: &#39;./app.component.html&#39;,
  styleUrls: [&#39;./app.component.css&#39;],
})
export class AppComponent {
  originName = &#39;你好&#39;;

  getTranslatedName(name: string): string {
    console.log(&#39;getTranslatedName called for&#39;, name);
    return &#39;hello world!&#39;;
  }

  onClick() {
    console.log(&#39;Button clicked!&#39;);
  }
}

Angular のテンプレートでメソッドを呼び出さないのはなぜですか

テンプレート内の getTranslatedName メソッドを直接呼び出します。これにより、メソッド hello world の戻り値が簡単に表示されます。 問題はないようですが、コンソールを確認すると、このメソッドが複数回呼び出されていることがわかります。

Angular のテンプレートでメソッドを呼び出さないのはなぜですか

ボタンをクリックすると、originName を変更したくない場合でも、このメソッドの呼び出しが継続されます。

Angular のテンプレートでメソッドを呼び出さないのはなぜですか

理由は、Angular の変更検出メカニズムに関連しています。通常、値が変更されたときに対応するモジュールを再レンダリングしたいと考えますが、Angular には関数の戻り値が変更されたかどうかを検出する方法がないため、変更が検出されるたびに 1 回しか実行できません。ボタンがクリックされると、originName が変更されていなくても、getTranslatedName

が実行されるのはこのためです。クリック イベントではなく、その他のイベントをバインドすると、 mouseenter、mouseleave、mousemove など、トリガーしやすい関数を使用すると、この関数が無意味に何百回または何千回も呼び出される可能性があり、リソースが大幅に浪費され、パフォーマンスの問題が発生する可能性があります。

#小さなデモ:

https://stackblitz.com/edit/angular-ivy-4bahvo?file=src/app/app.component.html

ほとんどの場合、記事が長くなりすぎないように、

onInit

import { Component, OnInit } from &#39;@angular/core&#39;;

@Component({
  selector: &#39;my-app&#39;,
  templateUrl: &#39;./app.component.html&#39;,
  styleUrls: [&#39;./app.component.css&#39;],
})
export class AppComponent implements OnInit {
  originName = &#39;你好&#39;;
  TranslatedName: string;

  ngOnInit(): void {
    this.TranslatedName = this.getTranslatedName(this.originName)
  }
  getTranslatedName(name: string): string {
    console.count(&#39;getTranslatedName&#39;);
    return &#39;hello world!&#39;;
  }

  onClick() {
    console.log(&#39;Button clicked!&#39;);
  }
}

を割り当てるか、

pipe を使用するなど、代替案を常に見つけることができます。ただ、これ以上の詳細はありません。

プログラミング関連の知識について詳しくは、

プログラミング ビデオをご覧ください。 !

以上がAngular のテンプレートでメソッドを呼び出さないのはなぜですかの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はjuejin.cnで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。