对比了各种日历插件后选择了FullCalendar,根据需求需要显示节假日和节气,顺带把农历也加上,网上看了FeiFei些的《fullCalendar改造计划之带农历节气节假日的万年历》文章,按照他的方法改造发现他用的是老版本的插件,新版本代码结构变动很大,无奈自己重新读源码改造之,记录下来,给有需求的朋友一点参考。
FullCalendar官网(https://fullcalendar.io/)
改造使用新的版本,v 3.0.1。
首先看下改造成功后的预览图吧:
一、汉化
现在插件已经自带了本地化文件,所以直接加载插件包中的locale/zh-cn/js
即可。
二、增加农历,节气,节假日显示
关于直接调用Google Calendar的订阅我就不说了,墙的厉害。
下面说说直接修改源文件,这个就麻烦点,不过自定义程度很高,缺点就是插件更新麻烦。
按照FeiFei的方法,使用hao123的js库(点击下载lunar.js),这个库包含了农历、节气和节假日。
直接将lunar.js内容拷贝到fullcalendar.js里放在头部或者单独加载这个js都可以,看个人习惯。这里我是直接放在fullcalendar.js里,然后修改插件生成日期单元格的内容部分:
先搜索fc-day-number
,查找到以下代码:
修改为:
再修改buildGotoAnchorHtml方法,将其中span标签改为div标签:
好了,到这里就差不多完成了,接下来改下fullcalendar的样式就OK了:
1
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
|
/* 改造 */
.
fc
-
toolbar
.
fc
-
left
{
position
:
absolute
;
top
:
0
;
left
:
0
;
float
:
none
;
}
.
fc
table
>
thead
>
tr
>
th
div
{
font
-
weight
:
bold
;
color
:
#25992E;
font
-
size
:
14px
;
}
.
fc
-
sat
span
,
.
fc
-
sun
div
{
color
:
#ED6D23 !important;
}
.
fc
-
ltr
.
fc
-
basic
-
view
.
fc
-
day
-
top
.
fc
-
day
-
number
{
width
:
100
%
;
text
-
align
:
right
;
display
:
block
;
font
-
size
:
20px
;
font
-
family
:
Arial
;
font
-
weight
:
600
;
padding
:
12px
12px
0
12px
;
line
-
height
:
23px
;
height
:
23px
;
color
:
#555;
}
.
fc
-
day
-
cnTerm
{
text
-
align
:
right
;
padding
:
12px
12px
0
12px
;
color
:
#6ABA49;
font
-
size
:
12px
;
}
.
fc
-
day
-
cnDate
{
text
-
align
:
right
;
padding
:
12px
12px
0
12px
;
color
:
#999;
font
-
size
:
12px
;
}
|