首页 > 解决方案 > 如何在 Angular 5 应用程序中禁用来自组件的输入

问题描述

我正在开发 Angular 5 应用程序。我有反应形式,它们都工作正常。现在,当用户单击复选框 true 时,我需要禁用输入。一切正常,我想知道如何禁用组件的输入。我成功获得了输入的 id 但不知道下一步该怎么做???

零件

private handleQuestionAnswerProvidedStateChange(questionAnswerProvidedState:QuestionAnswerProvidedStateDataModel)
{
  console.log(">>>>>>> questionAnswerProvidedStateEvent ",questionAnswerProvidedState);
  var elementReference = document.getElementById(questionAnswerProvidedState.QuestionId);
  console.log("elementReference ",elementReference);
}

模板

 <div *ngSwitchCase="'textbox'"> <small>textbox</small>
           <div class="form-group">
               <input *ngSwitchCase="'textbox'" 
                      [formControlName]="question.key" 
                      [id]="question.key" 
                      [type]="question.type"
                      [(ngModel)]="question.value" 
                      (keyup.enter)="onChangeValue($event, previousValue, responseId, question.key, 'textbox'); previousValue = question.value" 
                      (blur)="onChangeValue($event,  previousValue, responseId, question.key, 'textbox'); previousValue = question.value"
                      (focus)="previousValue=question.value"
                      >
           </div>            
       </div>

下面的文本是循环的,所以会有很多输入,每个都有唯一的 id

标签: angularangular-reactive-forms

解决方案


#inputEl为输入元素 创建模板引用并在组件文件中使用它。

<div class="form-group">
                   <input #inputEl
                          *ngSwitchCase="'textbox'" 
                          [formControlName]="question.key" 
                          [id]="question.key" 
                          [type]="question.type"
                          [(ngModel)]="question.value" 
                          (keyup.enter)="onChangeValue($event, previousValue, responseId, question.key, 'textbox'); previousValue = question.value" 
                          (blur)="onChangeValue($event,  previousValue, responseId, question.key, 'textbox'); previousValue = question.value"
                          (focus)="previousValue=question.value"
                          >
               </div>

ViewChild()使用组件 .ts 文件中的输入元素创建属性并设置disabled = true

组件.ts

@ViewChild('inputEl') public inputEl: ElementRef;

fun() {
  this.inputEl.nativeElement.disabled = true;
}

编辑 :

由于输入是动态生成的,并且每个元素的 id 都被获取。

以下应该有帮助:

document.getElementById(questionAnswerProvidedState.QuestionId).setAttribute('disabled', 'true');


推荐阅读