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如何设... 透视插件!wepoker如何设置透视,wepoker私人局俱乐部怎么进,手筋教程(真是真的是有挂)-...
透视安卓版!we poker辅... 透视安卓版!we poker辅助器,约局吧怎么看有没有挂,绝活儿教程(果然是真的挂)-哔哩哔哩1、让...
透视透视!hardrock透视... 透视透视!hardrock透视工具,poker master辅助,资料教程(都是存在有挂)-哔哩哔哩...
透视苹果版!wepoker黑侠... 透视苹果版!wepoker黑侠辅助器,sohoo开挂辅助,要领教程(真是有挂)-哔哩哔哩1、不需要A...
透视挂!wepoker私人局辅... 您好,wepoker私人局辅助挂这款游戏可以开挂的,确实是有挂的,需要了解加去威信【13670430...
透视新版!wepoker辅助方... 透视新版!wepoker辅助方法,hhpoker开挂教程,技法教程(一直是有挂)-哔哩哔哩1、每一步...
透视免费!pokeplus脚本... 透视免费!pokeplus脚本,wpk俱乐部辅助器,课程教程(有挂实锤)-哔哩哔哩1、透视免费!po...
透视科技!hhpoker俱乐部... 透视科技!hhpoker俱乐部是干嘛的,hhpoker软件可以玩吗,教程书教程(有挂讲解)-哔哩哔哩...
透视讲解!aapoker公共底... 透视讲解!aapoker公共底牌,wepoker底牌透视,模板教程(有挂教学)-哔哩哔哩1、进入到a...
透视软件!德州局脚本,拱趴大菠... 透视软件!德州局脚本,拱趴大菠萝挂哪里,资料教程(有挂总结)-哔哩哔哩1、玩家可以在拱趴大菠萝挂哪里...