繁体   English   中英

将日期绑定到Angular DatePicker组件的Kendo UI

[英]Binding to a Date to a Kendo UI for Angular DatePicker Component

我收到一个“'值'应该是有效的JavaScript日期实例”。 尝试绑定到Datepicker或Timepicker组件的Kendo UI时出错。 Kendo Docs有一个页面讨论如何处理这种情况,但是我无法将其应用于我的情况。

我正在从服务器接收数据并放入我的打字稿对象:

export interface Event {
  id: number;
  name: string;
  date: Date;
  startTime: Date;
  endTime?: Date;
}

调试打字稿对象时,这些值最终看起来如下所示:

id:1
name:"Event 1"
date:"2018-11-01T00:00:00"
startTime:"2018-11-01T08:30:00"
endTime:"2018-11-01T10:30:00"

下面是我的component.ts(如果我执行this.event = this.parse(data.event),我没有收到任何错误,并且似乎可以正常工作,但是我所有不是日期的字段都从parse函数变成了随机日期:

ngOnInit() {
    if (!(this.route.snapshot.url[0].path === 'new')) {
      this.isUpdating = true;
      this.route.data
        .subscribe((data: { event: Event }) => {
          this.event = data.event;
        });
    }
  }
      public handleChange(value: Date) {
        this.event.startTime = new Date(this.intl.formatDate(value, 'yyyy-MM-dd HH:mm:ss'));
        this.event.endTime = new Date(this.intl.formatDate(value, 'yyyy-MM-dd HH:mm:ss'));
        this.event.date = new Date(this.intl.formatDate(value, 'yyyy-MM-dd HH:mm:ss'));
      }

      // A simple method for the string-to-date conversion
      private parse(json) {
        Object.keys(json).map(key => {
          const date = new Date(json[key]);
          if (!isNaN(date.getTime())) { json[key] = date; }
        });

        return json;
      }

以下是.html中我的组件的外观:

<kendo-datepicker [(value)]="event.date" id="date" name="date" style="width: 100%;" (valueChange)="handleChange($event)"></kendo-datepicker>

<kendo-timepicker [(value)]="event.startTime" id="startTime" name="startTime" style="width: 100%;" (valueChange)="handleChange($event)"></kendo-timepicker>

<kendo-timepicker [(value)]="event.endTime" id="endTime" name="endTime" style="width: 100%;" (valueChange)="handleChange($event)"></kendo-timepicker>

该方法似乎不是很可靠。 Date构造函数可以从数字创建日期(以1970年为单位,以毫秒为单位)。根据浏览器的格式,它也许还可以根据“事件1”字符串创建日期(Chrome似乎可以这样做)。 我在这里看到两个选择。 尝试使用特定格式解析日期字符串:

private parseExact(json) {
    Object.keys(json).map(key => {
      const date = this.intl.parseDate(json[key], 'yyyy-MM-ddTHH:mm:ss');
      if (date) { json[key] = date; }
    });

    return json;
}

或传递日期字段:

private parse(json: any, dateFields: string[]) {
   for (let idx = 0; idx < dateFields.length; idx++) {
       const field = dateFields[idx]; 
       const value = json[field];
       if (value) {
         json[field] = new Date(value);
       }
   }

   return json;
}

https://stackblitz.com/edit/angular-1jujzo?file=app/app.component.ts

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM