我正在尝试绘制有 3 行的表格。第一行应该有月份名称,第二个 - 一个月的天数和一周的第三天。像这样的东西:
我设法做了一些看起来像这样的事情,但仅限于 2013 年。我想获得特定时间段的自定义表。因此,如果我指定我想要从 2013-01-15 到 2013-02-10 的表格,那么它将在第二行和第三行有 27 列,在第一行有 2 列(具有正确的行跨度)。
这就是我现在拥有的:http: //jsfiddle.net/Misiu/amEug/
这是我当年的表格生成代码:
var monthNames = ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"];
var monthDays = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];
var dayNames = ["Mo", "Tu", "We", "Th", "Fr", "Sa", "Sn"];
var months = '';
for (var i = 0; i < monthNames.length; i++) {
months += '<td colspan="' + monthDays[i] + '">' + monthNames[i] + '</td>';
}
$('tr#months').html(months);
var numbers = '';
var counter = 1;
var month = 0;
for (i = 0; i < 365; i++) {
numbers += '<td>' + counter + '</td>';
counter++;
if (counter > monthDays[month]) {
month++;
counter = 1;
}
}
$('tr#numbers').html(numbers);
var days = '';
var day = 0;
for (i = 0; i < 365; i++) {
days += '<td' + (dayNames[day] == 'Sa' || dayNames[day] == 'Sn' ? ' class="weekend"' : '') + '>' + dayNames[day] + '</td>';
day++;
if (day > 6) day = 0;
}
$('tr#days').html(days);
我也希望它尽可能快,因为如果由于某种原因我需要很长的时间(4 年),我希望它能够快速渲染(即使在 IE8 上)。
有关如何使这项工作发挥作用的任何建议都会有所帮助。我查看了 jQuery UI datepicker 代码,但它很复杂并且具有我不需要的所有功能。