这次的项目中用到了一个js的日期控件WebCalendar.js,这个js文件还是以前在大连工作时一个朋友推荐的,最大的特点是调用简单,支持firefox浏览器。这次项目中就直接用了。不过在测试的时候发现,通过该js显示出来的日期在firefox中星期显示不正常。比如:2008-04-01在ie中显示为星期二(正确),在firefox中显示为星期日(不正确)。如下图:
图一(ie下日期截图)


从图中可以看出,在firefox下日期显示是不正常的。上网查了一下,发现好多人发现了这个问题,但就是没有已修改过的。
求人不如求己,既然没有现成的,就自己研究下它的源代码吧。经过读它的源代码,发现了问题所在,它有一个“绑定数据到月份视图”的函数。其内容如下:
1
//
绑定数据到月视图
2
Calendar.prototype.bindData
=
function
()
{
3
var calendar = this;
4
var dateArray = this.getMonthViewArray(this.date.getYear(), this.date.getMonth());
5
var tds = this.getElementById("calendarTable").getElementsByTagName("td");
6
for(var i = 0; i < tds.length; i++)
{
7
//tds[i].style.color = calendar.colors["td_word_light"];
8
tds[i].style.backgroundColor = calendar.colors["td_bg_out"];
9
tds[i].onclick = function ()
{return;}
10
tds[i].onmouseover = function ()
{return;}
11
tds[i].onmouseout = function ()
{return;}
12
if (i > dateArray.length - 1) break;
13
tds[i].innerHTML = dateArray[i];
14
if (dateArray[i] != " ")
{
15
tds[i].onclick = function ()
{
16
if (calendar.dateControl != null)
{
17
calendar.dateControl.value = new Date(calendar.date.getFullYear(),
18
calendar.date.getMonth(),
19
this.innerHTML).format(calendar.dateFormatStyle);
20
}
21
calendar.hide();
22
}
23
tds[i].onmouseover = function ()
{
24
this.style.backgroundColor = calendar.colors["td_bg_over"];
25
}
26
tds[i].onmouseout = function ()
{
27
this.style.backgroundColor = calendar.colors["td_bg_out"];
28
}
29
if (new Date().format(calendar.dateFormatStyle) ==
30
new Date(calendar.date.getFullYear(),
31
calendar.date.getMonth(),
32
dateArray[i]).format(calendar.dateFormatStyle))
{
33
//tds[i].style.color = calendar.colors["cur_word"];
34
tds[i].style.backgroundColor = calendar.colors["cur_bg"];
35
tds[i].onmouseover = function ()
{
36
this.style.backgroundColor = calendar.colors["td_bg_over"];
37
}
38
tds[i].onmouseout = function ()
{
39
this.style.backgroundColor = calendar.colors["cur_bg"];
40
}
41
//continue; //若不想当天单元格的背景被下面的覆盖,请取消注释
42
}
43
44
if (calendar.dateControl != null && calendar.dateControl.value == new Date(calendar.date.getFullYear(),
45
calendar.date.getMonth(),
46
dateArray[i]).format(calendar.dateFormatStyle))
{
47
tds[i].style.backgroundColor = calendar.colors["sel_bg"];
48
tds[i].onmouseover = function ()
{
49
this.style.backgroundColor = calendar.colors["td_bg_over"];
50
}
51
tds[i].onmouseout = function ()
{
52
this.style.backgroundColor = calendar.colors["sel_bg"];
53
}
54
}
55
}
56
}
57
}
这个函数就是用来绑定日期到月份表格中的。出错的地方,就在上面代码的第4行,this.date.getYear(),这句话上。这句话是得到当前的年份。但是遗憾的是在firefox中,getYear()函数不能正确返回当前年份。firefox的算法是当前年减去1900,也就是说,当前年是2008年的话,firefox中返回的是108,而不是2008。

2



3

4

5

6



7

8

9



10



11



12

13

14



15



16



17

18

19

20

21

22

23



24

25

26



27

28

29

30

31

32



33

34

35



36

37

38



39

40

41

42

43

44

45

46



47

48



49

50

51



52

53

54

55

56

57

问题找到了,解决起来就简单了,把this.date.getYear()修改为this.date.getFullYear(),即在firefox中显示正常了。
修改后的WebCalendar.js文件下载 /Files/longer/WebCalendar.rar