Reactive Form valueChanges observable 重置表单值

Posted

技术标签:

【中文标题】Reactive Form valueChanges observable 重置表单值【英文标题】:Reactive Form valueChanges observable resets form value 【发布时间】:2019-09-23 23:41:50 【问题描述】:

我有一个动态反应形式。一部分是通过在 html 中绑定 FormGroup 和 FormControl 指令来构建的。此外,还有一个单击事件,用于以编程方式将其他值添加到表单值。 问题是,当订阅 this.form.valueChanges observable 时,回调值(lambda 表达式)包括正在添加到 AddToList 函数中的表单值,但它是空的,虽然它之前有值。 每当我更改选择控件中的值时,都会订阅 valueChanges。 无法理解为什么会这样。

<form *ngIf="form" >
<div *ngFor="let col of Colomns">
    <ul>
        <li *ngFor="let val of col.dataList; let i=index">
          <span>val</span>
          <a button type="button" (click)="deleteFromList(i, col.field, $event)">
          </a>
        </li>
    </ul>
</div>
<!--below is the part of binding values using the directives-->
  <div *ngFor="let col of Colomns; let i = index">
    <div [formGroup]="form">
      <select [id]="col.field" [formControlName]="col.field" >
        <option [value]=''></option>
        <option *ngFor="let sys of col.data" [value]="sys.Code">sys.Value</option>
      </select>
  <!-- this is a textbox with an AddToList button-->
      <div>
       <input class="input" [id]="col.field" type="text"  #texttosearch>
       <button class="btnAddList" (click)="AddToList(texttosearch.value, 
        col.field, $event)">
       </button>
      </div>
    </div>
</div>

这是组件所需的代码:

export class dynamicReactiveFrom

    form: FormGroup;
    advanceCols: AdvanceColumnBase<any>[];
    constructor(private fb: FormBuilder)  

    initAdvancedSearch(arr:AdvanceColumnBase<any>[]) 
    
         this.advanceCols = arr;
         let group: any = ;
         arr.forEach(col =>
         if (<some condition for the selected Items>)
         
            group[col.field] = new FormControl(col.value || '');
         
         else/*This is for the items which were added using the AddToList function*/
         
            group[col.field] = this.fb.array([this.fb.control('')]);
         
         );
         this.form = new FormGroup(group);


         this.form.valueChanges.subscribe(values => 
         /*the value that was set in the AddToList function is now reset, in 
         the values callback*/
         doSeomthing(values);
     );
   

   AddToList(value: string, field: string, event) 
   
       event.preventDefault();
       let selectedField = this.advanceCols.find( x => x.field === field);
       if(selectedField) 
       
         this.form.value[field] = item.dataList;
       
   
 

从组件外部触发的 initAdvancedSearch 函数具有填充表单所需的值。

【问题讨论】:

【参考方案1】:

从 initAdvancedSearch 方法中删除值更改订阅,并在组件的 OnInit 上订阅它。首先实现 OnInit 接口:

export class dynamicReactiveFrom implement OnInit

然后提供一个ngOnInint的实现:

public ngOnInit() 
   this.form.valueChanges.subscribe(values => 
         /*the value that was set in the AddToList function is now reset, in 
         the values callback*/
         doSeomthing(values);
     );

【讨论】:

不,没有帮助。【参考方案2】:

找到问题所在 - 我在添加项目的 ul 中缺少 FormArrayName 指令:

<div *ngFor="let col of Colomns">
    <ul [formArrayName] = "col.<property with unique value - name or ID>">
        <li *ngFor="let val of col.dataList; let i=index">
         <span>val</span>
         <a button type="button" (click)="deleteFromList(i, col.field, $event)">
        </a>
       </li>
  </ul>
</div>

而不是这样做:

this.form.value[field] = item.dataList;

我在做:

this.form.value[field].push(value);

问题在于 form.value[field] 被 item.dataList 引用,而不是单独管理。

【讨论】:

以上是关于Reactive Form valueChanges observable 重置表单值的主要内容,如果未能解决你的问题,请参考以下文章

form.valueChanges 不会为禁用的控件发出值

FormControl 上的 ValueChanges 在 Form.enable 时触发,即使使用 emitEvent: false

从子 React Reactive Form 更新父状态变量

Angular Reactive Form 的深拷贝?

angular reactive form

typescript 使用FormBuilder和AngularMaterial的Angular - Reactive Form