* NgFor生成的输入文本的值绑定问题

时间:2019-07-05 09:07:19

标签: angular typescript data-binding ngfor

当尝试对ng中的数组进行* ngFor生成输入文本元素并将其绑定到数组中的值时,我遇到了一些问题。当用户在文本输入中输入内容时,该值未正确绑定。

我在更新数组后尝试运行changeDetection,但没有帮助。

在下面的代码示例中,使用字符串值“ test”的数据数组单击添加按钮时,生成输入元素。输入的[ngModel]绑定到Array中的值。所以我希望所有输入都具有“测试”的价值。

但是当我们尝试在输入中输入一些值然后单击添加按钮时,生成的输入不会绑定到数组中的值。

https://stackblitz.com/edit/angular-uywkxr

import { Component } from '@angular/core';
@Component({
  selector: 'my-app',
  template: `
    <button (click)="onAdd()">Add</button>
    <br/><br/>
    <input
      *ngFor="let d of data;let i = index;trackBy:trackByfn" 
      type="text"
      [ngModel]="data[i]"
    > 
    <br/><br/>
    data: {{data|json}}
  `,
  styleUrls: [ './app.component.css' ]
})
export class AppComponent  {
  data = ['test'];  
  onAdd() {  
    this.data.push('test');
  }
  trackByfn = (index) => index;
}

3 个答案:

答案 0 :(得分:0)

您必须将[ngModel]更改为[(ngModel)]才能进行双向数据绑定。

有关角度数据绑定的更多信息:https://blog.thoughtram.io/angular/2016/10/13/two-way-data-binding-in-angular-2.html

import { Component } from '@angular/core';
@Component({
  selector: 'my-app',
  template: `
    <button (click)="onAdd()">Add</button>
    <br/><br/>
    <input 
      *ngFor="let d of data;let i = index;trackBy:trackByfn" 
      type="text"
      [(ngModel)]="data[i]"
    /> 
    <br/><br/>
    data: {{data|json}}
  `,
  styleUrls: [ './app.component.css' ]
})
export class AppComponent  {
  data = ['test'];  
  onAdd() {  
    this.data.push('test');
  }
  trackByfn = (index) => index;
}

更新:使用表单组

import { Component } from '@angular/core';
import { FormGroup, FormControl, Validators, AbstractControl } from '@angular/forms';

@Component({
  selector: 'my-app',
  template: `
    <button (click)="onAdd()">Add</button>
    <div [formGroup]="form" *ngFor="let f of fields">
      <input type="text" [formControlName]="f" /> 
    </div>
    <div *ngFor="let f of fields">
      {{form.controls[f].value}}
    </div>
  `,
  styleUrls: [ './app.component.css' ]
})
export class AppComponent  {
  form: FormGroup = new FormGroup({
    test: new FormControl('test')
  });
  fields = ['test'];
  onAdd() {
    const length = this.fields.length;
    this.fields.push('test'+length);
    this.form.addControl('test'+length, new FormControl('test'));
  } // length to dynamically name the field
}

注意:请不要忘记在ReactiveFormsModule

的导入依赖项中添加app.module.ts

我分叉了您的堆叠炸弹: https://stackblitz.com/edit/angular-2t157s

答案 1 :(得分:0)

  

工作示例stackblitz

这是两种绑定语法---> [(ngModel)] 保持变量以获取新值

  import { Component } from '@angular/core';
    @Component({
      selector: 'my-app',
      template: `

    <br/><br/>
    <input *ngFor="let d of data;let i = index;trackBy:trackByfn" 
    type="text" [value]="data[i]" [(ngModel)]="dataarray"> 
     <button (click)="onAdd(data[i])">Add</button>
    <br/><br/>
    data: {{data|json}}
      `,
      styleUrls: [ './app.component.css' ]
    })
    export class AppComponent  {

       data = ["ssdsdsd"];
       datatosave:any;  
      onAdd(data1) {  
        this.data.push(this.datatosave);

      }
      trackByfn = (index) => index;
    }

答案 2 :(得分:0)

使用@ViewChildren指令。在onAdd()中,inputs的最后一个元素被推到data[]。这是stackblitz的意思。

代码:

import { Component, ViewChildren, ElementRef, 
         QueryList, AfterViewInit } from '@angular/core';

@Component({
  selector: 'my-app',
  template: `
  <button (click)="onAdd()">Add</button>
  <br/><br/>
  <input #inputRef type="text" 
  *ngFor="let d of data; let i = index; trackBy:trackByfn"> 
  <br/><br/>
  data: {{data | json}}
  `,
  styleUrls: ['./app.component.css']
})
export class AppComponent {
  data = ['test'];

  @ViewChildren("inputRef") inputs: QueryList<ElementRef>;

  onAdd() {
    let domElement = this.inputs.last as ElementRef;
    this.data.push(domElement.nativeElement.value);
  }

}

可以在official docs中找到有关@ViewChildren的更多信息。