亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

基于jquery實現日歷簽到功能

2019-11-20 11:10:52
字體:
來源:轉載
供稿:網友

在一些任務游戲、貼吧管理中都會有一個簽到功能,幫助大家記錄登錄天數,積累等級經驗,這個日歷簽到功能是如何實現的,本文為大家進行演。

本文實例講述了基于jquery實現日歷簽到功能。分享給大家供大家參考。具體如下:
運行效果截圖如下:

具體代碼如下:

index.html

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><title>簽到效果實現</title><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><script type="text/javascript" src="jquery-1.8.2.min.js"></script><link rel="stylesheet" type="text/css" href="sign.css"/><script type="text/javascript" src="calendar.js"></script><script type="text/javascript">$(function(){  //ajax獲取日歷json數據  var signList=[{"signDay":"10"},{"signDay":"11"},{"signDay":"12"},{"signDay":"13"}];   calUtil.init(signList);});</script></head><body><div style="width:300px;height:300px;" id="calendar"></div></body></html>

sign.css

.singer_r_img{display:block;width:114px;height:52px;line-height:45px;background:url(images/sing_week.gif) right 2px no-repeat;vertical-align:middle;*margin-bottom:-10px;text-decoration:none;}.singer_r_img:hover{background-position:right -53px;text-decoration:none;}.singer_r_img span{margin-left:14px;font-size:16px;font-family:'Hiragino Sans GB','Microsoft YaHei',sans-serif !important;font-weight:700;color:#165379;}.singer_r_img.current{background:url(images/sing_sing.gif) no-repeat 0 2px;border:0;text-decoration:none;}.sign table{border-collapse: collapse;border-spacing: 0;width:100%;}.sign th,.sign td {width: 30px;height: 40px;text-align: center;line-height: 40px;border:1px solid #e3e3e3;}.sign th {font-size: 16px;}.sign td {color: #404040;vertical-align: middle;}   .sign .on {background-color:red;}.calendar_month_next,.calendar_month_prev{width: 34px;height: 40px;cursor: pointer;background:url(images/sign_arrow.png) no-repeat;}.calendar_month_next {float: right;background-position:-42px -6px;}.calendar_month_span {display: inline;line-height: 40px;font-size: 16px;color: #656565;letter-spacing: 2px;font-weight: bold;}.calendar_month_prev {float: left;background-position:-5px -6px;}.sign_succ_calendar_title {text-align: center;width:398px;border-left:1px solid #e3e3e3;border-right:1px solid #e3e3e3;background:#fff;}.sign_main {width: 400px;border-top:1px solid #e3e3e3;font-family: "Microsoft YaHei",SimHei;}

calendar.js

var calUtil = {  //當前日歷顯示的年份  showYear:2015,  //當前日歷顯示的月份  showMonth:1,  //當前日歷顯示的天數  showDays:1,  eventName:"load",  //初始化日歷  init:function(signList){    calUtil.setMonthAndDay();    calUtil.draw(signList);    calUtil.bindEnvent();  },  draw:function(signList){    //綁定日歷    var str = calUtil.drawCal(calUtil.showYear,calUtil.showMonth,signList);    $("#calendar").html(str);    //綁定日歷表頭    var calendarName=calUtil.showYear+"年"+calUtil.showMonth+"月";    $(".calendar_month_span").html(calendarName);    },  //綁定事件  bindEnvent:function(){    //綁定上個月事件    $(".calendar_month_prev").click(function(){      //ajax獲取日歷json數據      var signList=[{"signDay":"10"},{"signDay":"11"},{"signDay":"12"},{"signDay":"13"}];      calUtil.eventName="prev";      calUtil.init(signList);    });    //綁定下個月事件    $(".calendar_month_next").click(function(){      //ajax獲取日歷json數據      var signList=[{"signDay":"10"},{"signDay":"11"},{"signDay":"12"},{"signDay":"13"}];      calUtil.eventName="next";      calUtil.init(signList);    });  },  //獲取當前選擇的年月  setMonthAndDay:function(){    switch(calUtil.eventName)    {      case "load":        var current = new Date();        calUtil.showYear=current.getFullYear();        calUtil.showMonth=current.getMonth() + 1;        break;      case "prev":        var nowMonth=$(".calendar_month_span").html().split("年")[1].split("月")[0];        calUtil.showMonth=parseInt(nowMonth)-1;        if(calUtil.showMonth==0)        {            calUtil.showMonth=12;            calUtil.showYear-=1;        }        break;      case "next":        var nowMonth=$(".calendar_month_span").html().split("年")[1].split("月")[0];        calUtil.showMonth=parseInt(nowMonth)+1;        if(calUtil.showMonth==13)        {            calUtil.showMonth=1;            calUtil.showYear+=1;        }        break;    }  },  getDaysInmonth : function(iMonth, iYear){   var dPrevDate = new Date(iYear, iMonth, 0);   return dPrevDate.getDate();  },  bulidCal : function(iYear, iMonth) {   var aMonth = new Array();   aMonth[0] = new Array(7);   aMonth[1] = new Array(7);   aMonth[2] = new Array(7);   aMonth[3] = new Array(7);   aMonth[4] = new Array(7);   aMonth[5] = new Array(7);   aMonth[6] = new Array(7);   var dCalDate = new Date(iYear, iMonth - 1, 1);   var iDayOfFirst = dCalDate.getDay();   var iDaysInMonth = calUtil.getDaysInmonth(iMonth, iYear);   var iVarDate = 1;   var d, w;   aMonth[0][0] = "日";   aMonth[0][1] = "一";   aMonth[0][2] = "二";   aMonth[0][3] = "三";   aMonth[0][4] = "四";   aMonth[0][5] = "五";   aMonth[0][6] = "六";   for (d = iDayOfFirst; d < 7; d++) {    aMonth[1][d] = iVarDate;    iVarDate++;   }   for (w = 2; w < 7; w++) {    for (d = 0; d < 7; d++) {     if (iVarDate <= iDaysInMonth) {      aMonth[w][d] = iVarDate;      iVarDate++;     }    }   }   return aMonth;  },  ifHasSigned : function(signList,day){   var signed = false;   $.each(signList,function(index,item){    if(item.signDay == day) {     signed = true;     return false;    }   });   return signed ;  },  drawCal : function(iYear, iMonth ,signList) {   var myMonth = calUtil.bulidCal(iYear, iMonth);   var htmls = new Array();   htmls.push("<div class='sign_main' id='sign_layer'>");   htmls.push("<div class='sign_succ_calendar_title'>");   htmls.push("<div class='calendar_month_next'>下月</div>");   htmls.push("<div class='calendar_month_prev'>上月</div>");   htmls.push("<div class='calendar_month_span'></div>");   htmls.push("</div>");   htmls.push("<div class='sign' id='sign_cal'>");   htmls.push("<table>");   htmls.push("<tr>");   htmls.push("<th>" + myMonth[0][0] + "</th>");   htmls.push("<th>" + myMonth[0][1] + "</th>");   htmls.push("<th>" + myMonth[0][2] + "</th>");   htmls.push("<th>" + myMonth[0][3] + "</th>");   htmls.push("<th>" + myMonth[0][4] + "</th>");   htmls.push("<th>" + myMonth[0][5] + "</th>");   htmls.push("<th>" + myMonth[0][6] + "</th>");   htmls.push("</tr>");   var d, w;   for (w = 1; w < 7; w++) {    htmls.push("<tr>");    for (d = 0; d < 7; d++) {     var ifHasSigned = calUtil.ifHasSigned(signList,myMonth[w][d]);     console.log(ifHasSigned);     if(ifHasSigned){      htmls.push("<td class='on'>" + (!isNaN(myMonth[w][d]) ? myMonth[w][d] : " ") + "</td>");     } else {      htmls.push("<td>" + (!isNaN(myMonth[w][d]) ? myMonth[w][d] : " ") + "</td>");     }    }    htmls.push("</tr>");   }   htmls.push("</table>");   htmls.push("</div>");   htmls.push("</div>");   return htmls.join('');  }};

希望本文所述對大家學習javascript程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品99久久久久中文字幕| 成人黄色短视频在线观看| 欧美成人免费在线视频| 91精品综合久久久久久五月天| 国产亚洲欧美日韩精品| 欧美精品免费看| 久久中文字幕一区| 亚洲人成在线电影| 欧美日韩亚洲网| 国产成人精品久久二区二区91| 国产69精品99久久久久久宅男| 欧美极品少妇xxxxⅹ裸体艺术| 中文字幕欧美日韩精品| 国产精品羞羞答答| 日韩精品小视频| 深夜福利亚洲导航| 精品视频中文字幕| 欧美一级免费视频| 91成人国产在线观看| 日韩国产欧美精品一区二区三区| 中文字幕日韩欧美在线| 亚洲欧美制服第一页| 欧美中文字幕视频| 日韩久久午夜影院| 91精品国产自产在线观看永久| 国内精品久久久久伊人av| 亚洲欧美日韩一区在线| 国产成一区二区| 国产精品www色诱视频| 97视频免费在线看| 在线丨暗呦小u女国产精品| 亚洲国产日韩欧美在线图片| 国产精品亚洲第一区| 欧美国产日韩视频| 国产精品一香蕉国产线看观看| 2019国产精品自在线拍国产不卡| 久久免费视频在线| 久久久久久久av| 欧美激情视频一区二区| 在线日韩日本国产亚洲| 97精品一区二区视频在线观看| 日韩二区三区在线| 不卡在线观看电视剧完整版| 国产精品第七影院| 91精品国产91久久| 国产精品普通话| 成人黄色生活片| 欧美国产在线视频| 国产精品日日摸夜夜添夜夜av| 日韩在线视频网| 欧美日韩人人澡狠狠躁视频| 久久久久久久久久久免费| 日韩国产在线看| 欧美日韩国产限制| 久久6免费高清热精品| 色偷偷噜噜噜亚洲男人的天堂| 精品成人国产在线观看男人呻吟| 欧美精品在线免费播放| 久久久天堂国产精品女人| 国模视频一区二区三区| 九九热最新视频//这里只有精品| 午夜精品一区二区三区av| …久久精品99久久香蕉国产| 51视频国产精品一区二区| 2020久久国产精品| 亚洲精品在线91| 久久亚洲国产成人| 97精品一区二区视频在线观看| 日韩成人在线免费观看| 欧美成人免费在线视频| 久久在线精品视频| 日韩av片电影专区| 亚洲美女av电影| 国产精品私拍pans大尺度在线| 欧美性猛交xxx| 这里只有精品视频在线| 91亚洲精品在线| 成人精品一区二区三区| 久久久久日韩精品久久久男男| 理论片在线不卡免费观看| 最新69国产成人精品视频免费| 午夜精品久久久久久99热| 欧美日韩国产丝袜另类| 国产精品久久一区主播| 欧美在线一区二区视频| 日本一欧美一欧美一亚洲视频| 欧美一级电影在线| 欧美日韩一二三四五区| 成人国产在线视频| 精品亚洲精品福利线在观看| 精品亚洲va在线va天堂资源站| 国自产精品手机在线观看视频| 欧美激情极品视频| 4k岛国日韩精品**专区| 亚洲精品国偷自产在线99热| 91精品在线观| 欧美性猛交99久久久久99按摩| 欧美大尺度激情区在线播放| 91在线观看免费观看| 国产成人在线精品| 国产69精品久久久久久| 国产欧美精品一区二区三区-老狼| 亚洲精品成人久久电影| 91免费国产网站| 国模叶桐国产精品一区| 日本免费在线精品| 日本电影亚洲天堂| 国产午夜精品一区理论片飘花| 久久精品91久久香蕉加勒比| 国产精品视频xxx| 欧美激情手机在线视频| 欧美日韩电影在线观看| 一区二区三区四区视频| 1769国产精品| 国产精品主播视频| xxav国产精品美女主播| 国内精品久久久久| 91精品国产91久久久久久最新| 色噜噜亚洲精品中文字幕| 性欧美视频videos6一9| 在线精品高清中文字幕| 亚洲最新视频在线| 成人午夜在线观看| 成人免费看黄网站| 最近的2019中文字幕免费一页| 成人黄色大片在线免费观看| 亚洲色图35p| 亚洲va国产va天堂va久久| 精品日韩美女的视频高清| 91sao在线观看国产| 国产精品亚洲片夜色在线| www.亚洲成人| 国产99久久精品一区二区 夜夜躁日日躁| 日本电影亚洲天堂| 久久精品国产久精国产一老狼| 国产精品永久免费观看| 精品香蕉在线观看视频一| 中文字幕成人在线| www.日韩系列| 亚洲天堂久久av| 欧美日韩免费观看中文| 成人一区二区电影| 91网站在线免费观看| 国产区精品在线观看| 亚洲精品国产电影| 亚洲精品xxxx| 久热精品视频在线观看一区| 精品视频在线观看日韩| www.欧美精品| 在线精品播放av| 国产精品网红福利| 亚洲欧美一区二区三区在线| 欧美国产日本高清在线| 久久在精品线影院精品国产| 亚洲精品白浆高清久久久久久| 亚洲午夜性刺激影院| 日韩精品中文在线观看| 97精品久久久| 自拍偷拍免费精品| 欧美日韩黄色大片| 亚洲精品美女久久久| 91在线观看免费| 亚洲成人久久一区| 欧美精品www|