2016-09-30 3 views
3

Я создаю компонент расписания, используя момент и реагирую. Я создал собственный календарь. Как установить дни недели, установленные наверху, как обычный календарь? Поэтому, если я передаю объект даты сентябрь, я хочу, чтобы все даты были указаны с правильным днем ​​недели над каждой датой. Здесь я создал скрипку.создание пользовательского календаря с моментом, использующим дни/недели и заголовки

https://jsfiddle.net/4dbwLg6b/

var dates = ['Thu Sep 01 2016 00:00:00 GMT+0800 (CST)', 'Fri Sep 02 2016 00:00:00 GMT+0800 (CST)', 'Sat Sep 03 2016 00:00:00 GMT+0800 (CST)', 'Sun Sep 04 2016 00:00:00 GMT+0800 (CST)', 'Mon Sep 05 2016 00:00:00 GMT+0800 (CST)', 'Tue Sep 06 2016 00:00:00 GMT+0800 (CST)', 'Wed Sep 07 2016 00:00:00 GMT+0800 (CST)', 'Thu Sep 08 2016 00:00:00 GMT+0800 (CST)', 'Fri Sep 09 2016 00:00:00 GMT+0800 (CST)', 'Sat Sep 10 2016 00:00:00 GMT+0800 (CST)', 'Sun Sep 11 2016 00:00:00 GMT+0800 (CST)', 'Mon Sep 12 2016 00:00:00 GMT+0800 (CST)', 'Tue Sep 13 2016 00:00:00 GMT+0800 (CST)',' Wed Sep 14 2016 00:00:00 GMT+0800 (CST)',' Thu Sep 15 2016 00:00:00 GMT+0800 (CST)', 'Fri Sep 16 2016 00:00:00 GMT+0800 (CST)', 'Sat Sep 17 2016 00:00:00 GMT+0800 (CST)', 'Sun Sep 18 2016 00:00:00 GMT+0800 (CST)', 'Mon Sep 19 2016 00:00:00 GMT+0800 (CST)',' Tue Sep 20 2016 00:00:00 GMT+0800 (CST)', 'Wed Sep 21 2016 00:00:00 GMT+0800 (CST)', 'Thu Sep 22 2016 00:00:00 GMT+0800 (CST)', 'Fri Sep 23 2016 00:00:00 GMT+0800 (CST)', 'Sat Sep 24 2016 00:00:00 GMT+0800 (CST)', 'Sun Sep 25 2016 00:00:00 GMT+0800 (CST)', 'Mon Sep 26 2016 00:00:00 GMT+0800 (CST)', 'Tue Sep 27 2016 00:00:00 GMT+0800 (CST)', 'Wed Sep 28 2016 00:00:00 GMT+0800 (CST)', 'Thu Sep 29 2016 00:00:00 GMT+0800 (CST)', 'Fri Sep 30 2016 00:00:00 GMT+0800 (CST)'] 
var Hello = React.createClass({ 
    render: function() { 


    return <div className="container"> 
     {dates.map(function(day){ 
    return(
    <div className="calendarDay"> 
    {moment(day).format('D').toString()} 
    </div> 
    ) 
    })} 
    </div>; 
    } 
}); 

ReactDOM.render(
    <Hello name="World" />, 
    document.getElementById('container') 
); 

это то, что я есть enter image description here

это то, что я хочу, дни недели, соответствующий дате количеству. пн, вт, ср ..... enter image description here

ответ

7

Понял, используя таблицу в качестве заголовков и пересчитывают недели и дни, используя момент

const startWeek = moment().startOf('month').week(); 
const endWeek = moment().endOf('month').week(); 


let calendar = [] 
for(var week = startWeek; week<endWeek;week++){ 
    calendar.push({ 
    week:week, 
    days:Array(7).fill(0).map((n, i) => moment().week(week).startOf('week').clone().add(n + i, 'day')) 
    }) 
} 
+1

'момент ('2017-12-31') endOf ('месяц') неделю();' возвращение 1 –

+1

то потому что по.. до момента, это https://stackoverflow.com/questions/25631682/moment-js-thinks-that-2013-12-31-is-week-1-not-week-53 – caffeinescript

2

На основании ответа предоставленной caffeinescript я создал этот календарь, также будет работать в течение нескольких лет.

const startDay = moment().clone().startOf('month').startOf('week'); 
const endDay = moment().clone().endOf('month').endOf('week'); 

var calendar = []; 
var index = startDay.clone(); 
while (index.isBefore(endDay, 'day')) { 
    calendar.push(
     new Array(7).fill(0).map(
      function(n, i) { 
       return {date: index.add(1, 'day').date()}; 
      } 
     ) 
    ); 
} 
+0

Приблизительно один день добавляется * до * дата возвращается. Разве это не привело бы к неправильным датам в выходном массиве? – Sebastian

1

База по всем выше ответов:

 let calendar = []; 

     const startDay = this.date.clone().startOf('month').startOf('week'); 
     const endDay = this.date.clone().endOf('month').endOf('week'); 

     let date = startDay.clone().subtract(1, 'day'); 

     while (date.isBefore(endDay, 'day')) { 
      calendar.push({ 
       days: Array(7).fill(0).map(() => date.add(1, 'day').clone()) 
      }) 
     } 
Смежные вопросы