Angular 2 – 为什么不能注销输入值
我觉得我必须在这里遗漏一些东西,并想知道是否有更好的方法来做到这一点.
我有一个指令,基本上将一个类添加到输入字段的父元素.在加载时我需要检查输入字段是否有值,你认为这很简单…… 我现在使用了一些不同的选项,包括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).我可能建议将父/输入组合配对到新组件中. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |