Angular5 template binding, callback function called more than once

|▌冷眼眸甩不掉的悲伤 提交于 2019-12-03 16:29:54

Angular handles the binding between the model and the dom (component and template file). To do this the application ticks (change detection cycle) and checks for if any values that have changed, and if so -> Update the dom.

The problem is when you have functions in your template file, and each cycle angular will call the function to check if the 'value' has changed.

For example, if I had a simple get function which only returned a value, Angular needs to run it to check that there is actually a change.

{{ myValue() }} // in the template file

myValue() { return 10 } // in the component

Here it makes sense that angular must call the function each to check if the value has changed.

A solution (if you don't want Angular to be constantly calling your functions), is to implement a ChangeDectionStrategy (https://angular.io/api/core/ChangeDetectionStrategy). With this, you can tell Angular that you will handle the updates, and when it should run the cycle (for only that component).

To do so within the component metadata you will add the following:

@Component({
  selector: 'app-table',
  templateUrl: './table.component.html',
  styleUrls: ['./table.component.css'],
  changeDetection: ChangeDetectionStrategy.OnPush // the new line
})

Then in the constructor:

constructor(private changeDetectorRef: ChangeDetectorRef) {}

Whenever you make a change, you can then call this.changeDetectorRef.markForCheck(); which will manually run the cycle for this component and update the dom when needed.

I really suggest reading into this more as the topic is too broad to describe in this one post

when you have a template binding that calls a method (which here is col.callback(row[col.field]) ), the method will be called everytime something triggers your component's change-detection (angular renders your component's html and hence, calls all those bound methods). and because of that you'll see the console logs. and because the method is called inside an ngFor's template, it's called for each item of it.

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!