首先寫出一個日歷我們需要考慮以下2個問題:
- 每個月的總天數
- 每個月的第一天周幾
這里提供了一個判斷平年閏年2月份天數的方法:
function leapYear(year) {
return (year%100==0?res=(year%400==0?1:0):res=(year%4==0?1:0));
}
1.因此可以得到12個月份天數的數組:
const monthDays = new Array(31, 28 + leapYear(year), 31, 30, 31, 31, 30, 31, 30, 31, 30, 31)
因為獲取到的月份是0-11,所有剛好和數組的下標對應上。
2.獲取每個月的1日是星期幾:
let monthDayOne = new Date(2019, 12, 1) const firstday = monthDayOne .getDay()
通過月總天數和該月第一天是星期幾兩個條件就可以得到行數,解決表格所需行數問題:(當前月天數+第一天是星期幾的數值)/ 7
const date = new Date() const mnow = date.getMonth() const tr_str = Math.ceil((monthDays[mnow] + firstday)/7);
其次就是渲染問題了
完整的js代碼如下:
const date = new Date()
const {year, month, day} = {
year: date.getFullYear(),
month: date.getMonth(),
day: date.getDate()
}
let monthDayOne = new Date(year, month, 1)
const firstday = monthDayOne.getDay()
const monthDays = new Array(31, 28 + leapYear(year), 31, 30, 31, 30, 31, 31, 30, 31, 30, 31)
const tr_str = Math.ceil((monthDays[month] + firstday) / 7)
function leapYear(year) {
return (year%100==0?res=(year%400==0?1:0):res=(year%4==0?1:0));
}
這是我寫的一個簡單的渲染:
//打印表格第一行(有星期標志)
document.write ("<table border='1' align='center' width='220' cellspacing='0'><tr><td align='center'>日</td><td align='center'>一</td><td align='center'>二</td><td align='center'>三</td><td align='center'>四</td><td align='center'>五</td><td align='center'>六</td></tr>");
for(i=0;i<tr_str;i++) { //表格的行
document.write("<tr>");
for(k=0;k<7;k++) { //表格每行的單元格
idx=i*7+k; //單元格自然序列號
date_str=idx-firstday+1; //計算日期
(date_str<=0 || date_str>m_days[mnow]) ? date_str=" " : date_str=idx-firstday+1; //過濾無效日期(小於等於零的、大於月總天數的)
//打印日期:今天底色為紅
date_str==dnow ? document.write ("<td align='center' bgcolor='red'>" + date_str + "</td>") : document.write ("<td align='center'>" + date_str + "</td>");
}
document.write("</tr>"); //表格的行結束
}
document.write("</table>"); //表格結束
效果如下:

