angular4中ngFor中遇到的问题

发布于 2022-09-07 08:36:21 字数 908 浏览 15 评论 0

现有以下代码:

Component

import { Component } from '@angular/core';

@Component({
    selector: 'app-root',
    templateUrl: './app.component.html',
    styleUrls: ['./app.component.scss']
})
export class AppComponent {
    title = 'app';

    i = 0;

    data = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10];

    itemChecked(item) {
        this.i++;
        console.log(item, this.i);
    }

}

Template

<ul>
  <li *ngFor="let item of data">
    {{itemChecked(item)}} {{item}}
  </li>
</ul>

页面显示的结果:

clipboard.png

Console输出的结果:

clipboard.png

页面是按照预期的情况显示的,但是控制台中并不是,也就是说,模板中的ngFor被调用了4次!

这个是什么原因呢? 或者能否避免这种情况呢?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

木緿 2022-09-14 08:36:21

不推荐在模版上直接调用函数,每次变更检测都会执行。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文