加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

Angular 2 – 为什么不能注销输入值

发布时间:2020-12-17 17:29:52 所属栏目:安全 来源:网络整理
导读:我觉得我必须在这里遗漏一些东西,并想知道是否有更好的方法来做到这一点. 我有一个指令,基本上将一个类添加到输入字段的父元素.在加载时我需要检查输入字段是否有值,你认为这很简单…… 我现在使用了一些不同的选项,包括ngOnInit,AfterContentInit和AfterVie
我觉得我必须在这里遗漏一些东西,并想知道是否有更好的方法来做到这一点.

我有一个指令,基本上将一个类添加到输入字段的父元素.在加载时我需要检查输入字段是否有值,你认为这很简单……

我现在使用了一些不同的选项,包括ngOnInit,AfterContentInit和AfterViewInit.但对于下面我仍然在AfterContentInit:

ngAfterContentInit() {
  console.log(this.el.nativeElement); // Element Object "Value is not empty if you look inside the object."
  console.log(this.el.nativeElement.value); // = ''

  setTimeout(() => {
    console.log(this.el.nativeElement.value); // = 'The Value!'
  },1000);

  this.activeStateCheck(this.el.nativeElement);
}

activeStateCheck(element) {
  if (element.value !== '') {
    element.parentElement.classList.add('active');
    return true;
  }
}

我应该指出,所有选项都会给出相同的结果.

第一个控制台注销一个空字符串,第二个控制台注销实际字符串.在这种情况下,它是’大巡回赛’.

我的问题是如何在不使用setTimeout的情况下执行此操作?

它似乎必须等待数据加载到页面上才能记录该值.但是我的印象是OnInit是要等待这个完成的?

我想找到更好的解决方案的原因是因为如果页面加载时间超过一秒,那么控制台日志将输出一个空字符串,因此不是一个完整的解决方案.

这是被调用指令的一个例子.注意appPlaceholder属性:

<fieldset class="form__placeholder">
    <input type="text" 
            id="lastName" 
            formControlName="lastName" 
            appPlaceholder>
    <label for="lastName"
           class="form__placeholder--label">
      Lastname:
    </label>
</fieldset>

解决方法

从您告诉我们的内容来看,我不确定您是否需要自定义指令.如果您真的想要将“活动”类添加到非空输入的父级,您可以这样做

<div [ngClass]={'active': groupForm.get('name').value !== ''}>
  <input formControlName="lastName">
</div>

您甚至可以省略!==”,因为空字符串是假的.

如果出于某些其他原因绝对需要指令,则可以将formControlName视为指令的输入,@ Input()formControlName;,但是如果这样做,则还需要传入formGroup.更改父行为但是,一个孩子看起来很麻烦,特别是你正在做的直接DOM操作(改为使用HostBinding).我可能建议将父/输入组合配对到新组件中.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读