我想通过管道将一些数字写入<input>
并动态显示为小数。{{}}
它会引发异常。这是我的代码:
app.template.html:
<h1>amount = {{amount|number:'1.2-2'}}</h1>
<input [(ngModel)]="amount"/>
app.component.ts:
import {Component} from '@angular/core';
@Component({
selector: 'my-app',
templateUrl: 'app/app.template.html'
})
export class AppComponent {
private amount:number;
}
Plunker:http ://plnkr.co/edit/I7ynnwBX4DWJfHNPIPRu?p=preview
将任何数字写入输入并查看控制台中抛出的异常。
编辑:
根据 rinukkusu 建议的工作代码:
app.template.html:
<h1>amount = {{amount|number:'1.2-2'}}</h1>
<input [ngModel]="amount" (ngModelChange)="onChange($event)"/>
app.component.ts:
import { Component } from '@angular/core';
@Component({
selector: 'my-app',
templateUrl: 'app/app.template.html'
})
export class AppComponent {
private amount:number;
onChange($event) {
this.amount = +$event;
}
}
这非常重要,是什么使从字符串到数字的转换成为可能+
!$event