200字范文,内容丰富有趣,生活中的好帮手!
200字范文 > 带图片的日历html js css+html实现简单的日历

带图片的日历html js css+html实现简单的日历

时间:2023-03-05 08:59:52

相关推荐

带图片的日历html js css+html实现简单的日历

web页面中很多地方都会用到日历显示,选择等,本文用html、css、javascript实现简单的日历。完成以后的效果与页面左侧的效果差不多,可以切换上个月、下个月。也可以根据实际情况进行扩展。

html

html部分比较简单,声明一个div,具体的html用javascript生成。整体内容大概是这样的:

1

2

3

4

5

6

7

8

9

10

11

12

demo

css

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

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86/* 整体设置 */

*{margin:0px;padding:0px;}

/**

* 设置日历的大小

*/

.calendar{

width:240px;

height:400px;

display:block;

}

/**

* 设置日历顶部盒子

*/

.calendar .calendar-title-box{

position:relative;

width:100%;

height:36px;

line-height:36px;

text-align:center;

border-bottom:1px solid #ddd;

}

/**

* 设置上个月的按钮图标

*/

.calendar .prev-month {

position:absolute;

top:12px;

left:0px;

display: inline-block;

width:0px;

height:0px;

border-left:0px;

border-top:6px solid transparent;

border-right:8px solid #999;

border-bottom:6px solid transparent;

cursor:pointer;

}

/**

* 设置下个月的按钮图标

*/

.calendar .next-month {

position:absolute;

top:12px;

right:0px;

display: inline-block;

width:0px;

height:0px;

border-right:0px;

border-top:6px solid transparent;

border-left:8px solid #999;

border-bottom:6px solid transparent;

cursor:pointer;

}

/* 设置日历表格样式 */

.calendar-table{

width:100%;

border-collapse:collapse;

text-align:center;

}

/* 表格行高 */

.calendar-table tr{

height:30px;

line-height:30px;

}

/* 当前天 颜色特殊显示 */

.currentDay {

color:red;

}

/* 本月 文字颜色 */

.currentMonth {

color:#999;

}

/* 其他月颜色 */

.otherMonth{

color:#ede;

}

样式设置基本没什么课说的,一些简单的设置。比如特殊的是表示“上个月”、“下个月”的图标,采用的绝对定位、利用css中的border属性设置样式。

javascript Date对象开始正式的js代码之前,需要先了解js中的Date对象,通过Date对象,可以获取到年月日时分秒以及时间戳等信息,具体参考: /jsref/jsref_obj_date.asp

1

2

3

4

5var d1 =new Date();// 获取当前系统时间 我现在的时间是 4月25日 星期一

d1.getFullYear();// 获取年信息,

d1.getMonth();// 获取月信息(从0开始 范围:0-11) 3

d1.getDate();// 获取天信息 此处结果:25

d1.getDay();// 获取星期信息 (0-6) 此处结果: 1

也可以在初始化的时候直接设置年月日信息

1

2

3

4

5

6# 设置 3月15日

var d2 =new Date(, 2, 15);// 月是从0开始计数, 需要减一

d2.getFullYear();//

d2.getMonth();// 2

d2.getDate();// 15

d2.toLocaleDateString();// "/3/15" 证明设置正确

日历中会涉及到每个月多少天之类的问题,在js中很简单,如果设置年月日的时候,超出当月,js会自动算成下个月的,例如4月只有30天,如果设置成31 日,获得的Date类型中自动会算成5月1日;如果设置成5月0日,js会处理成4月30日,那么5月-1日也就是4月29日

1

2

3

4

5

6

7

8

9

10

11

12var d3 =new Date(, 3, 30);

d3.toLocaleDateString();// "/4/30"

var d4 =new Date(, 3, 31);

d4.toLocaleDateString();// "/5/1"

var d5 =new Date(, 3, 33);

d5.toLocaleDateString();// "/5/3"

var d6 =new Date(, 4, 1);

d6.toLocaleDateString();// "/5/1"

var d7 =new Date(, 4, 0);

d7.toLocaleDateString();// "/4/30"

var d8 =new Date(, 4, -3);

d8.toLocaleDateString();// "/4/27"

javascript了解了js中Date对象的基本用法,接下来就是代码实现部分了,整体思路是这样的:定义一个全局的dateObj变量,用来记录表格中需要显示的 年月信息。 标题中的内容根据dateObj中取,表格中的日期则中dateObj中取到年月对应的1号的所有信息,即可确定1号在表格第一行的位置,以此倒推上个月 最后几天的数据、正推本月和下个月的数据。

具体步骤:

1.声明dateObj变量,并赋初值为当前系统时间

2.给calendar div中渲染html元素

3.通过dateObj获取当月1号的信息,并以此遍历出表格中所有日期

4.给上一月、下一月图标绑定事件

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

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

138

139

140

141

142

143

144

145

146

147

148

149

150

151

152

153

154

155

156

157

158

159

160

161

162

163(function(){

/*

* 用于记录日期,显示的时候,根据dateObj中的日期的年月显示

*/

var dateObj = (function(){

var _date =new Date();// 默认为当前系统时间

return {

getDate :function(){

return _date;

},

setDate :function(date) {

_date = date;

}

};

})();

// 设置calendar div中的html部分

renderHtml();

// 表格中显示日期

showCalendarData();

// 绑定事件

bindEvent();

/**

* 渲染html结构

*/

function renderHtml() {

var calendar = document.getElementById("calendar");

var titleBox = document.createElement("div");// 标题盒子 设置上一月 下一月 标题

var bodyBox = document.createElement("div");// 表格区 显示数据

// 设置标题盒子中的html

titleBox.className ='calendar-title-box';

titleBox.innerHTML ="" +

"" +

"";

calendar.appendChild(titleBox);// 添加到calendar div中

// 设置表格区的html结构

bodyBox.className ='calendar-body-box';

var _headHtml ="

" +

"

日" +

"

一" +

"

二" +

"

三" +

"

四" +

"

五" +

"

六" +

"

";

var _bodyHtml ="";

// 一个月最多31天,所以一个月最多占6行表格

for(var i = 0; i < 6; i++) {

_bodyHtml +="

" +

"

" +

"

" +

"

" +

"

" +

"

" +

"

" +

"

" +

"

";

}

bodyBox.innerHTML ="

_headHtml + _bodyHtml +

"

";

// 添加到calendar div中

calendar.appendChild(bodyBox);

}

/**

* 表格中显示数据,并设置类名

*/

function showCalendarData() {

var _year = dateObj.getDate().getFullYear();

var _month = dateObj.getDate().getMonth() + 1;

var _dateStr = getDateStr(dateObj.getDate());

// 设置顶部标题栏中的 年、月信息

var calendarTitle = document.getElementById("calendarTitle");

var titleStr = _dateStr.substr(0, 4) +"年" + _dateStr.substr(4,2) +"月";

calendarTitle.innerText = titleStr;

// 设置表格中的日期数据

var _table = document.getElementById("calendarTable");

var _tds = _table.getElementsByTagName("td");

var _firstDay =new Date(_year, _month - 1, 1);// 当前月第一天

for(var i = 0; i < _tds.length; i++) {

var _thisDay =new Date(_year, _month - 1, i + 1 - _firstDay.getDay());

var _thisDayStr = getDateStr(_thisDay);

_tds[i].innerText = _thisDay.getDate();

//_tds[i].data = _thisDayStr;

_tds[i].setAttribute('data', _thisDayStr);

if(_thisDayStr == getDateStr(new Date())) {// 当前天

_tds[i].className ='currentDay';

}else if(_thisDayStr.substr(0, 6) == getDateStr(_firstDay).substr(0, 6)) {

_tds[i].className ='currentMonth';// 当前月

}else {// 其他月

_tds[i].className ='otherMonth';

}

}

}

/**

* 绑定上个月下个月事件

*/

function bindEvent() {

var prevMonth = document.getElementById("prevMonth");

var nextMonth = document.getElementById("nextMonth");

addEvent(prevMonth,'click', toPrevMonth);

addEvent(nextMonth,'click', toNextMonth);

}

/**

* 绑定事件

*/

function addEvent(dom, eType, func) {

if(dom.addEventListener) {// DOM 2.0

dom.addEventListener(eType,function(e){

func(e);

});

}else if(dom.attachEvent){// IE5+

dom.attachEvent('on' + eType,function(e){

func(e);

});

}else {// DOM 0

dom['on' + eType] =function(e) {

func(e);

}

}

}

/**

* 点击上个月图标触发

*/

function toPrevMonth() {

var date = dateObj.getDate();

dateObj.setDate(new Date(date.getFullYear(), date.getMonth() - 1, 1));

showCalendarData();

}

/**

* 点击下个月图标触发

*/

function toNextMonth() {

var date = dateObj.getDate();

dateObj.setDate(new Date(date.getFullYear(), date.getMonth() + 1, 1));

showCalendarData();

}

/**

* 日期转化为字符串, 4位年+2位月+2位日

*/

function getDateStr(date) {

var _year = date.getFullYear();

var _month = date.getMonth() + 1;// 月从0开始计数

var _d = date.getDate();

_month = (_month > 9) ? ("" + _month) : ("0" + _month);

_d = (_d > 9) ? ("" + _d) : ("0" + _d);

return _year + _month + _d;

}

})();

本例中并没有添加点击表格中日期时候的事件,可以在bindEvent函数中添加如下代码获取所点击日期的信息

1

2

3

4

5

6

7var table = document.getElementById("calendarTable");

var tds = table.getElementsByTagName('td');

for(var i = 0; i < tds.length; i++) {

addEvent(tds[i],'click',function(e){

console.log(e.target.getAttribute('data'));

});

}

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。