0

所以我想为 RBC 使用周视图。我不断收到 TypeError: date[("get" + method)] is not a function

有一些问题报告都说我需要一个date对象,实际上,我可以在使用此示例时打开日历

var myEventsList = [{
 {
    'title': 'Meeting',
    'start': new Date(2017, 3, 12, 10, 30, 0, 0),
    'end': new Date(2017, 3, 12, 12, 30, 0, 0),
    desc: 'Pre-meeting meeting, to prepare for the meeting'
 },
   {
    'title': 'Lunch',
      'start':new Date(2017, 3, 12, 12, 0, 0, 0),
      'end': new Date(2017, 3, 12, 13, 0, 0, 0),
    desc: 'Power lunch'
  }]

所以我知道我需要将我的转换start: 2019-05-14T12:00:00.000Z,new Date( x,x,x,x,x)

我试过用这样的东西在后端做这个

      for (let i = 0; i < data.length; i++) {
          events.push({
          title: data[i].summary,
          start: new Date(data[i].start.dateTime),
          end: new Date(data[i].end.dateTime)

我还尝试moment(data[i].start.dateTime)了许多不同的 google 搜索建议,包括各种 .format()、.todate() 等,但我不断收到错误。

更新 :

我也试过用这个位在我的前端设置它

 const events=[]
 const makeDatobj = (data) =>{
   events.map(event => ({
    title : event.title,
     start : new Date(event.start)
   }));

我希望用它来初始化

    <BigCalendar
            ...
             localizer={localizer}
             events={events=>makedatobj(data)}
             step={70}
             timeslots={2}
             defaultView="week"
             ...
           />

但这给了我 TypeError: data.map is not a function

这只是提醒我,我不知道它是如何.map()工作的,当我尝试使用它时,我不断遇到类似的问题......我尝试了一些其他方法来解析具有类似失败程度的传入数据。我注意到,当我尝试处理传入的数据时,我无意中关闭了我的 api 请求,所以我没有任何数据可以使用......我真的让这种方式变得比它需要的更困难。

我只需要一个简单的答案。我该如何转换。start: 2019-05-14T12:00:00.000Z,开始:new date( x,x,x,x,x)?

4

1 回答 1

0

Date 构造函数也可以将字符串作为参数,所以你可以这样做:

start : new Date("2019-05-14T12:00:00.000Z")

所以听起来你的后端应该是这样的,将日期作为字符串返回:

for (let i = 0; i < data.length; i++) {
  events.push({
  title: data[i].summary,
  start: data[i].start.dateTime,
  end: data[i].end.dateTime
}

你的前端代码应该是这样的,将它们转换为 Javascript 日期:

events.map(event => ({
  title : event.title,
  start : new Date(event.start)
}));
于 2019-05-12T20:03:49.250 回答