私たちは、数百のフォームコントロールで反応性フォームを使用する非常に大きなAngular 2/4アプリケーションを持っています。依存関係注入のオーバーヘッドはどのような角度ですか?
約200のフォームコントロールコンポーネントにChangeDetectorRefインスタンスを挿入するだけで、かなりのオーバーヘッドがありますか?
変更検出基準用法:
https://angular.io/api/core/ChangeDetectorRef
私たちは、数百のフォームコントロールで反応性フォームを使用する非常に大きなAngular 2/4アプリケーションを持っています。依存関係注入のオーバーヘッドはどのような角度ですか?
約200のフォームコントロールコンポーネントにChangeDetectorRefインスタンスを挿入するだけで、かなりのオーバーヘッドがありますか?
変更検出基準用法:
https://angular.io/api/core/ChangeDetectorRef
コンポーネントビューのオブジェクトの周りViewRef_
ラッパーを作成する必要性から生じたわずかなオーバーヘッドがあります。 ChangeDetectorRef
自体は、ViewRef_
のインスタンスに過ぎません。ここで
はresolveDep
は、コンストラクタの時に角度のプロセスの依存関係と呼ばれる機能であるソースあちこちに関連するスニペットです:
function resolveDep(view, elDef, allowPrivateServices, depDef, notFoundValue) {
...
while (view) {
if (elDef) {
switch (tokenKey$$1) {
...
case ChangeDetectorRefTokenKey: {
var cdView = findCompView(view, elDef, allowPrivateServices);
return createChangeDetectorRef(cdView); <------ create a wrapper
}
export function createChangeDetectorRef(view: ViewData): ChangeDetectorRef {
return new ViewRef_(view);
}
は、基礎となるViewオブジェクトの詳細については、これらの記事を読む:
素晴らしいリソースbtw、ありがとう.. – ktsangop
@ktsangop、ありがとう、もっと多くのものが来ている:) –
あなたはそれらと何をするつもりですか? –
私はdetectChanges()を手動で呼び出します。なぜなら、それらの一部を再レイアウトしたいからです。そして、ChangeDetectionStrategyがOnPushに設定されています。 – ktsangop