主要分为三个部分,1:获取li元素 2:如何填写对应的日期 3:如何获取点击li元素的事件。
1:通过节点间关系的属性children 获取li元素(两个for循坏遍历);
2:在遍历填写日期时,在第一行判断在当月的第一天在星期几,然后从第一天开始填写,直到大于当月的天数就暂停填写,并开始填写下个月的日期。第一行上个月的日期显示 : 上月天数显示开始值 = 计算上个月的天数 - 这个月开始的第一天在星期几的值 -1,然后在第一行上月天数显示开始值自加。
3:利用js的事件冒泡获取li的innerhtml显示出对应日期
效果图:
代码如下:
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="generator" content="editplus®">
<meta name="author" content="">
<meta name="keywords" content="">
<meta name="description" content="">
<title>calendar</title>
<style>
.clear:after{
content:"";
display:table;
clear:both;
}
.left{
float:left;
}
ul{
padding:0px;
margin-top:5px;
margin-bottom:0px;
}
ul>li{
float:left;
list-style:none;
width:30px;
height: 21px;
border: 1px solid #ccc;
text-align:center;
}
.gray{
color:#766565;
}
.top {
height:25px;
}
.top .lf-tri{
border:10px solid transparent;
border-right-color:black;
margin-top:4px;
}
.top .rf-tri{
border:10px solid transparent;
border-left-color:black;
margin-top:4px;
}
.top .content{
width:185px;
height:5px;
text-align:center;
}
</style>
</head>
<body>
<p class="top clear">
<p class="left lf-tri" onclick="lastmonth()"></p>
<p class="left content">2017年2月1日</p>
<p class="left rf-tri" onclick=" nextmonth()"></p>
</p>
<p>
<p id="week">
<ul class="clear">
<li>日</li>
<li>一</li>
<li>二</li>
<li>三</li>
<li>四</li>
<li>五</li>
<li>六</li>
<ul>
</p>
<p id="date" onclick='getdatenum(event)'>
<ul class="clear">
<li>30</li>
<li>31</li>
<li>1</li>
<li>2</li>
<li>3</li>
<li>4</li>
<li>5</li>
</ul>
<ul class="clear">
<li>6</li>
<li>7</li>
<li>8</li>
<li>9</li>
<li>10</li>
<li>11</li>
<li>12</li>
</ul>
<ul class="clear">
<li>13</li>
<li>14</li>
<li>15</li>
<li>16</li>
<li>17</li>
<li>18</li>
<li>19</li>
</ul>
<ul class="clear">
<li>20</li>
<li>21</li>
<li>22</li>
<li>23</li>
<li>24</li>
<li>25</li>
<li>26</li>
</ul>
<ul class="clear">
<li>27</li>
<li>28</li>
<li>1</li>
<li>2</li>
<li>3</li>
<li>4</li>
<li>5</li>
</ul>
<ul class="clear">
<li>27</li>
<li>28</li>
<li>1</li>
<li>2</li>
<li>3</li>
<li>4</li>
<li>5</li>
</ul>
</p>
<p>
<script>
function $(id){
return document.getelementbyid(id);
}
function change(cls){
return document.getelementsbyclassname(cls);
}
function getdatenum(e) {
console.log(e && e.target.nodename)//打印发生事件的元素,再获取元素nodename
if(e.target.nodename=="li"){//先判断nodename是li
if(e.target.classname!="gray"){//点击本月的日期,显示在日期栏
change("content")[0].innerhtml = year+'年'+(month+1)+'月'+e.target.innerhtml+'日';
}else{//点击灰色日期即(上个月或者下个月日期)切换到当月
if(e.target.innerhtml>14){
lastmonth();
}else {
nextmonth();
}
}
}
}
//获取年、月
var today = new date();
var year=today.getfullyear(), month = today.getmonth();
var totalday;
var uls=$("date").children,list;
function loadcalendar(){
totalday=getmonthdays(year,month+1);//计算一个月的天数
var firstday = (new date(year,month,1)).getday();//计算每个月1号在星期几
var lastmonthday=getmonthdays(year,month);
var lastdaycal=lastmonthday-firstday+1;//计算上个月在第一行显示的天数
//获取ul元素
var num=1 ,nextnum=1;//日期显示
// 类数组对象 转 数组
//uls = array.prototype.slice.call(uls)
//获取li元素 填充
for(var r=0;r<uls.length;r++){
list=uls[r].children;//遍历ul,获得li
for(var line=0;line<list.length;line++){
if(r==0){//在第一行 与第一天进行判断 大于等于第一天时载入日期
if(line>=firstday){
list[line].innerhtml=num++;
list[line].setattribute("class","");
}else {
list[line].innerhtml=lastdaycal++;//第一行的上个月天数显示
list[line].setattribute("class","gray");
}
}else {
//判断是否超出天数 ,不超出则继续加,超出则显示下个月日期
if(num<=totalday){
list[line].setattribute("class","");
list[line].innerhtml=num++;
}else {
list[line].innerhtml=nextnum++;//下个月日期显示
list[line].setattribute("class","gray");
}
}
}
}
}
loadcalendar();
function getmonthdays(year,month){
//判断2月份天数
if(month==2){
days= (year%4==0)&&(year%100!=0)||(year%400==0)? 29:28;
}else {
//1-7月 单数月为31日
if(month<7){
days= month%2==1?31:30;
}else {
//8-12月 双月为31日
days = month%2==0?31:30;
}
}
return days;
}
//右击箭头下个月
//change("rf-tri")[0].onclick =
function nextmonth() {
month++;
if(month>11){
year+=1;
month=0;
}
change("content")[0].innerhtml=year+"年"+(month+1)+"月"+"1日";
//console.log(month+1);
loadcalendar();
}
//左击箭头上个月
//change("lf-tri")[0].onclick =
function lastmonth() {
month--;
if(month<0){
month=11;
year-=1;
}
change("content")[0].innerhtml=year+"年"+(month+1)+"月"+"1日";
//console.log(month+1);
loadcalendar();
}
</script>
</body>
</html>
更多js实现一个简单的日历。