我覺得老師的邏輯過程還是清晰的,只是我們或者是不了解日歷,或者是日期函數部分不熟悉,我可能有點笨,看了四遍才搞明白整個過程,在老師那個水平也沒法再簡單講解了
2017-04-25
for(var i=0; i<monthData.days.length; i++){
if(i % 7 == 0) html += '<tr>'
html += '<td data-date="'+ monthData.days[i].date+'">' + monthData.days[i].showDate + '</td>'
if(i % 7 == 6) html += '</tr>';
}
if(i % 7 == 0) html += '<tr>'
html += '<td data-date="'+ monthData.days[i].date+'">' + monthData.days[i].showDate + '</td>'
if(i % 7 == 6) html += '</tr>';
}
for(var i=0; i<monthData.days.length; i++){
if(i % 7 == 0) html += '<tr>'
html += '<td data-date="'+ monthData.days[i].date+'">' + monthData.days[i].showDate + '</td>'
if(i % 7 == 6) html += '</tr>';
}
if(i % 7 == 0) html += '<tr>'
html += '<td data-date="'+ monthData.days[i].date+'">' + monthData.days[i].showDate + '</td>'
if(i % 7 == 6) html += '</tr>';
}
(function(){
var datePicker={};
datePicker.getMonthData=function(year,month){
}
window.datePicker=datePicker;
})()為什么要寫window.datePicker=datePicker;?
var datePicker={};
datePicker.getMonthData=function(year,month){
}
window.datePicker=datePicker;
})()為什么要寫window.datePicker=datePicker;?
日歷顯示上個月preMonthDayCount天,即 i 從 0 到 preMonthDayCount-1 都是上一個月的數據。那么當月1號對應的i: preMonthDayCount-1 + 1;當月date號對應的i: i = preMonthDayCount-1 + date;也就是 date = i + 1 - preMonthDayCount。老師很少注釋,而且好多地方可能沒錄制完整,我自己根據寫了一份,CSS用了Sass省得那一堆class一直疊加。https://github.com/lusg02/js-components
2017-04-22