Angular2:将 [(ngModel)] 与 [ngModelOptions]="{standalone: true}" 一起使用到 link 以引用模型的 属性
Angular2: use [(ngModel)] with [ngModelOptions]="{standalone: true}" to link to a reference to model's property
假设我有一个 Mailtype 类型的打字稿对象,如下所示:
export class Mailtype {
constructor(
public name?: string,
public locale?: string,
public email?: string,
public properties? : Property[]
) { }
}
它的“属性”字段是属性:
类型的数组
export class Property {
constructor(
public name?: string,
public type?: string,
public example?: string,
public required?: boolean,
public masked?: boolean
) { }
}
现在在我的组件中,我有一个 Mailtype 对象,html 有一个用于编辑和添加到 Mailtype 的属性数组的表单元素:
<form>
<tr *ngFor="let property of model.properties; let i=index">
<td>
<input type="text" [(ngModel)]="property.name" required>
</td>
</tr>
<button (click)="onAddProperty()">Add property</button>
</form>
组件:
export class MailtypeComponent {
model : Mailtype;
constructor() {
this.model = new Mailtype('','','',[]);
this.model.properties.push(new Property());
}
onAddProperty() {
this.model.properties.push(new Property());
}
}
我想知道是否不允许我使用 [(ngModel)] 到 link 到数组中数组元素的引用“属性”,尤其是在同一时间我正在迭代数组?因为上面的代码会抛出如下错误:
ORIGINAL EXCEPTION: If ngModel is used within a form tag, either the name attribute must be set
or the form control must be defined as 'standalone' in ngModelOptions.
Example 1: <input [(ngModel)]="person.firstName" name="first">
Example 2: <input [(ngModel)]="person.firstName" [ngModelOptions]="{standalone: true}">
所以建议我使用 [ngModelOptions]="{standalone: true}"
或向 html 添加名称字段。看起来 [ngModelOptions]="{standalone: true}"
在这种情况下有效。 standalone: true
是什么意思,因为我找不到任何关于它的文档?
当您使用 <form>
标签时使用 @angular/forms
它会自动创建一个 FormGroup
.
对于每个包含 ngModel
标记的 <input>
它将创建一个 FormControl
并将其添加到上面创建的 FormGroup
中;此 FormControl
将使用属性 name
.
命名为 FormGroup
示例:
<form #f="ngForm">
<input type="text" [(ngModel)]="firstFieldVariable" name="firstField">
<span>{{ f.controls['firstField']?.value }}</span>
</form>
说到这里,你的问题的答案如下。
当您将其标记为 standalone: true
时,不会发生这种情况(不会添加到 FormGroup
)。
参考:https://github.com/angular/angular/issues/9230#issuecomment-228116474
我的代码:
<form (submit)="addTodo()">
<input type="text" [(ngModel)]="text">
</form>
抛出错误,但我在输入中添加了名称属性:
<form (submit)="addTodo()">
<input type="text" [(ngModel)]="text" name="text">
</form>
它开始起作用了。
<form (submit)="addTodo()">
<input type="text" [(ngModel)]="text">
</form>
假设我有一个 Mailtype 类型的打字稿对象,如下所示:
export class Mailtype {
constructor(
public name?: string,
public locale?: string,
public email?: string,
public properties? : Property[]
) { }
}
它的“属性”字段是属性:
类型的数组export class Property {
constructor(
public name?: string,
public type?: string,
public example?: string,
public required?: boolean,
public masked?: boolean
) { }
}
现在在我的组件中,我有一个 Mailtype 对象,html 有一个用于编辑和添加到 Mailtype 的属性数组的表单元素:
<form>
<tr *ngFor="let property of model.properties; let i=index">
<td>
<input type="text" [(ngModel)]="property.name" required>
</td>
</tr>
<button (click)="onAddProperty()">Add property</button>
</form>
组件:
export class MailtypeComponent {
model : Mailtype;
constructor() {
this.model = new Mailtype('','','',[]);
this.model.properties.push(new Property());
}
onAddProperty() {
this.model.properties.push(new Property());
}
}
我想知道是否不允许我使用 [(ngModel)] 到 link 到数组中数组元素的引用“属性”,尤其是在同一时间我正在迭代数组?因为上面的代码会抛出如下错误:
ORIGINAL EXCEPTION: If ngModel is used within a form tag, either the name attribute must be set
or the form control must be defined as 'standalone' in ngModelOptions.
Example 1: <input [(ngModel)]="person.firstName" name="first">
Example 2: <input [(ngModel)]="person.firstName" [ngModelOptions]="{standalone: true}">
所以建议我使用 [ngModelOptions]="{standalone: true}"
或向 html 添加名称字段。看起来 [ngModelOptions]="{standalone: true}"
在这种情况下有效。 standalone: true
是什么意思,因为我找不到任何关于它的文档?
当您使用 <form>
标签时使用 @angular/forms
它会自动创建一个 FormGroup
.
对于每个包含 ngModel
标记的 <input>
它将创建一个 FormControl
并将其添加到上面创建的 FormGroup
中;此 FormControl
将使用属性 name
.
FormGroup
示例:
<form #f="ngForm">
<input type="text" [(ngModel)]="firstFieldVariable" name="firstField">
<span>{{ f.controls['firstField']?.value }}</span>
</form>
说到这里,你的问题的答案如下。
当您将其标记为 standalone: true
时,不会发生这种情况(不会添加到 FormGroup
)。
参考:https://github.com/angular/angular/issues/9230#issuecomment-228116474
我的代码:
<form (submit)="addTodo()">
<input type="text" [(ngModel)]="text">
</form>
抛出错误,但我在输入中添加了名称属性:
<form (submit)="addTodo()">
<input type="text" [(ngModel)]="text" name="text">
</form>
它开始起作用了。
<form (submit)="addTodo()">
<input type="text" [(ngModel)]="text">
</form>