Angular如何在数据相同时检测输入?
创始人
2024-10-29 08:00:52
0

可以通过创建自定义的比较函数来解决这个问题。该函数将比较输入数据和原始数据是否相同。如果数据相同,则不会更新输入组件。以下是一个示例:

import { Component, Input, SimpleChanges, OnChanges, ChangeDetectorRef } from '@angular/core';

@Component({
  selector: 'app-custom-input',
  template: `
    
  `
})
export class CustomInputComponent implements OnChanges {

  @Input() data: any;
  inputValue: any;

  constructor(private cdr: ChangeDetectorRef) {}

  ngOnChanges(changes: SimpleChanges) {
    if (typeof changes.data !== 'undefined') {
      const currentValue = changes.data.currentValue;
      const previousValue = changes.data.previousValue;

      if (currentValue !== previousValue) {
        this.inputValue = currentValue;
      }

      this.cdr.detectChanges();
    }
  }
}

在这个示例中,我们在组件中定义了一个data输入,并创建了一个比较函数ngOnChanges。ngOnChanges会在每次输入发生变化时被调用。如果数据发生变化,比较函数将更新输入组件。如果数据未发生变化,则不会更新输入组件。最后,我们使用cdr.detectChanges()强制组件检测变化并更新。

相关内容

热门资讯

透视辅助(WEPOKER)we... 透视辅助(WEPOKER)wepokerplus外挂(透视)原来存在有挂(详细教程);1、下载好we...
透视安卓版(WePoKer)w... 透视安卓版(WePoKer)wepoker透视苹果系统(透视)一直真的有挂(实用技巧)一、wepok...
透视规律(WEPOKER)we... 透视规律(WEPOKER)wepoker有没有挂(透视)果然是有挂(可靠教程);1、完成wepoke...
透视了解(wepoker)we... 透视了解(wepoker)wepoker免费透视脚本(透视)真是真的是有挂(科技教程);1、wepo...
透视教学(WEPOKER)we... 透视教学(WEPOKER)wepoker私人局外卦(透视)一直存在有挂(透牌教程)1、进入到wepo...
透视最新(WePoKer)we... 透视最新(WePoKer)wepoker透视脚本免费(透视)一直是有挂(揭秘攻略);进入游戏-大厅左...
透视工具(wepoker)we... 透视工具(wepoker)wepoker私人局辅助挂(透视)其实有挂(安装教程)1、构建自己的wep...
透视存在(WEPOKER)we... 透视存在(WEPOKER)wepoker透视方法(透视)原来有挂(插件教程)wepoker透视方法辅...
透视脚本(wepoker)we... 透视脚本(wepoker)wepoker辅助是真的假的(透视)果然存在有挂(wpk教程);1、用户打...
透视教学(WePoKer)we... 透视教学(WePoKer)wepoker透视有用吗(透视)真是有挂(曝光教程)1、起透看视 wepo...