将日期对象绑定到日期输入的默认值。但不工作

pep*_*ode 2 forms typescript ecmascript-6 angular angular-forms

我正在尝试通过属性绑定设置日期类型输入的默认值。

首先我在 app.component.ts 中创建了一个新的 date 对象,然后将[value]date的属性绑定到currentDateapp.component.ts 中的属性。但它不起作用

// 表单模板

<section class="container">
  <div class="panel panel-default">
    <div class="panel-heading">Add a Task</div>
    <div class="panel-body">
      <form class="form-horizontal" [formGroup]="taskForm" (ngSubmit)="onSubmit()">
        <div class="form-group">
          <label for="title" class="col-sm-2 control-label">Title *</label>
          <div class="col-sm-10">
            <input type="text" class="form-control" id="taskTitle" placeholder="Title of Task" formControlName="taskTitle">
          </div>
        </div>
        <div class="form-group">
          <label for="description" class="col-sm-2 control-label">Description *</label>
          <div class="col-sm-10">
            <input type="text" class="form-control" id="description" placeholder="Enter Your Description" formControlName="description">
          </div>
        </div>
        <div class="form-group">
          <label for="date" class="col-sm-2 control-label">Date of Completion *</label>
          <div class="col-sm-10">
            <input type="date" class="form-control" id="date" formControlName="date" [value]="currentDate">
          </div>
        </div>
        <div class="form-group">
          <div class="col-md-offset-6">
            <button type="submit" class="btn btn-default">Submit your data</button>
          </div>
        </div>
      </form>
    </div>
  </div>
</section>
<section class="container">
  <app-task-list></app-task-list>
</section>
Run Code Online (Sandbox Code Playgroud)

// 应用组件

import { Component, OnInit } from '@angular/core';
import { FormGroup, FormControl } from '@angular/forms';
@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css']
})
export class AppComponent implements OnInit {
  currentDate: {};
  taskForm: FormGroup;

  ngOnInit() {
    this.taskForm = new FormGroup({
      'taskTitle': new FormControl(''),
      'description': new FormControl(''),
      'date': new FormControl(null)
    });
    this.currentDate = new Date();
    console.log(this.currentDate);
  }

  onSubmit() {

  }
}
Run Code Online (Sandbox Code Playgroud)

Lau*_*ens 6

如果日期不是表单/输入期望的格式,则不会显示日期。您可以在组件中转换日期或使用管道。

配管:

<form>
  <input 
      type="date" class="form-control" 
      name="currentDate" [ngModel]="currentDate | date:'yyyy-MM-dd'">
</form>
Run Code Online (Sandbox Code Playgroud)

不带管道

成分:

currentStringDate;
constructor() {
    this.currentStringDate = new Date().toISOString().substring(0, 10);
}
Run Code Online (Sandbox Code Playgroud)

HTML:

<input type="date" class="form-control" name="currentStringDate" [ngModel]="currentStringDate">
Run Code Online (Sandbox Code Playgroud)

编辑:不要忘记在你的 html 中使用 name 标签,它需要与 ngModel 变量同名