前言

方法是有参考网上一些资料的,比如闰年的判断,比如每个月第一天是星期几的判断。不说太多,拆分出一个个函数,希望能描述尽可能的清晰明了。

一,判断闰年

//判断闰年
function runNian(_year) {
if(_year% === || (_year% === && _year% !== ) ) {
return true;
}
else { return false; }
}

二,判断某年某月的1号是星期几

//判断某年某月的1号是星期几
function getFirstDay(_year,_month) {
var allDay = , y = _year-, i = ;
allDay = y + Math.floor(y/) - Math.floor(y/) + Math.floor(y/) + ;
for ( ; i<_month; i++) {
switch (i) {
case : allDay += ; break;
case :
if(runNian(_year)) { allDay += ; }
else { allDay += ; }
break;
case : allDay += ; break;
case : allDay += ; break;
case : allDay += ; break;
case : allDay += ; break;
case : allDay += ; break;
case : allDay += ; break;
case : allDay += ; break;
case : allDay += ; break;
case : allDay += ; break;
case : allDay += ; break;
}
}
return allDay%;
}

三,创建日历表格,显示日历(表格应该在静态页面先写好结构和样式,然后在此处拼接,这里仅做示范,不附样式)

//显示日历
function showCalendar(_year,_month,_day,firstDay) {
var i = ,
monthDay = ,
showStr = "",
_classname = "",
today = new Date();
//月份的天数
switch(_month) {
case : monthDay = ; break;
case :
if(runNian(_year)) { monthDay = ; }
else { monthDay = ; }
break;
case : monthDay = ; break;
case : monthDay = ; break;
case : monthDay = ; break;
case : monthDay = ; break;
case : monthDay = ; break;
case : monthDay = ; break;
case : monthDay = ; break;
case : monthDay = ; break;
case : monthDay = ; break;
case : monthDay = ; break;
} //输出日历表格,这部分因结构而异
showStr = "<table class='cld-w'><thead>";
//日历头部
showStr += "<tr><th colspan='7'><div class='cld-hd'><span class='cld-pre'>&lt;</span><em id='showDate' value='" + _year + "-" + _month + "-" + _day + "'>" + _year + "年" + _month + "月" + _day + "日" + "</em><span class='cld-next'>&gt;</span></div></th></tr>";
//日历星期
showStr += "<tr><th>日</th><th>一</th><th>二</th><th>三</th><th>四</th><th>五</th><th>六</th></tr>";
showStr += "</thead><tbody><tr>";
//当月第一天前的空格
for (i=; i<=firstDay; i++) {
showStr += "<td></td>";
}
//显示当前月的天数
for (i=; i<=monthDay; i++) {
//当日的日期
if(_year === today.getFullYear() && _month === today.getMonth()+ && i === today.getDate()) {
_classname = "cld-cur";
}
//当日之前的日期(这个判断是因为我有工作需求,就是要求之前的日期不能点击)
else if(_year < today.getFullYear() || (_year === today.getFullYear() && _month <= today.getMonth()) || (_year === today.getFullYear() && _month === today.getMonth()+ && i < today.getDate()) ) {
_classname = "cld-old";
}
//其他普通的日期
else { _classname = "cld-day"; }
//其他大于当月的月份的相同日期(为了让点击下一月的时候,相同的日期增加cld-cur类)
if(_day === i && (_year > today.getFullYear() || _month > today.getMonth()+)) { _classname = "cld-cur"; }
//把日期存在对应的value
showStr += "<td class=" + _classname + " value='" + _year + "-" + _month + "-" + i + "'>" + i + "</td>"; firstDay = (firstDay+)%;
if(firstDay === && i !== monthDay) {
showStr += "</tr><tr>";
}
}

//剩余的空格
if(firstDay!==) {
for (i=firstDay; i<; i++) {
showStr += "<td></td>";
}
} showStr +="</tr></tbody></table>";
//插入calendar的页面结构里
calendar.innerHTML = showStr;
}

四,在日历的头部显示当前的年月日

//显示年月日
function showDate(_year,_month,_day) {
var date = "", firstDay = getFirstDay(_year,_month,_day);
if(_day !== ) {
date = _year + "年" + _month + "月" +_day + "日";
}
else { date = "No Choose."; }
document.getElementById("showDate").innerHTML = date; //日历头部显示
showCalendar(_year,_month,_day,firstDay); //调用日历显示函数
}

五,上一月和下一月

//上一月
function preMonth(_year,_month,_day) {
if(_month == ) { showDate(_year - ,,_day); }
else { showDate(_year,_month - ,_day); }
}
//下一月
function nextMonth(_year,_month,_day) {
if(_month == ) { showDate(_year + ,,_day); }
else { showDate(_year,_month + ,_day); }
}

六,初始化,日历就出来了

//初始化
var calendar = document.createElement('div');
calendar.setAttribute('id','showCld');
document.getElementById("box").appendChild(calendar); //增加到你的box里

//获取当天的年月日
var today = new Date();
var _year = today.getFullYear(),
_month = today.getMonth() + ,
_day = today.getDate();
var firstDay = getFirstDay(_year,_month); //显示日历
showCalendar(_year,_month,_day,firstDay);

七,日历的点击事件

//日历点击的事件委托(可以查查js冒泡的应用)
calendar.onclick = function(e) {
var e = e || window.event;
var target = e.srcElement || e.target;
//把日历的头部的年月日分割成数组,这里保存在其value属性上
dayArr = document.getElementById('showDate').getAttribute('value').split('-');
if (target) {
//如果是可点击的日期
if ( target.className === "cld-day" || target.className === "cld-cur" ) {
dateArr = target.getAttribute('value').split('-');
//减0是把字符串转化成数值类型,以下一样
showDate(dateArr[0]-0,dateArr[1]-0,dateArr[2]-0);
calendar.className = "";
}
//如果是上一月的点击
else if ( target.className === "cld-pre" ) {
preMonth(dayArr[]-,dayArr[]-,dayArr[]-);
}
//如果是下一月的点击
else if ( target.className === "cld-next" ) {
nextMonth(dayArr[]-,dayArr[]-,dayArr[]-);
}
}
};

——把解释都写着代码里了,代码函数比较简单粗暴,没办法,本人对js继承封装还不熟呢。

创建一个js日历(原生JS实现日历)的更多相关文章

  1. 再谈React.js实现原生js拖拽效果

    前几天写的那个拖拽,自己留下的疑问...这次在热心博友的提示下又修正了一些小小的bug,也加了拖拽的边缘检测部分...就再聊聊拖拽吧 一.不要直接操作dom元素 react中使用了虚拟dom的概念,目 ...

  2. JS(原生js和jq方式)获取元素属性(自定义属性),删除属性(自定义属性)

    JS(原生js和jq方式)获取元素属性(自定义属性),删除属性(自定义属性) 以下内容: 一.获取元素的属性 二.设置元素的属性 三.删除元素的属性 一.获取元素的属性 1-原生JS 获取属性 .ge ...

  3. 封装一个简单的原生js焦点轮播图插件

    轮播图实现的效果为,鼠标移入左右箭头会出现,可以点击切换图片,下面的小圆点会跟随,可以循环播放(为了方便理解,没有补2张图做无缝轮播).本篇文章的主要目的是分享封装插件的思路. 轮播图我一开始是写成非 ...

  4. 一个简单用原生js实现的小游戏----FlappyBird

    这是一个特别简单的用原生js实现的一个小鸟游戏,比较简单,适合新手练习 这是html结构 <!DOCTYPE html><html lang="en">&l ...

  5. jQuery跳转到另一个页面以及原生js跳转到另一个页面

    1.原生js我们可以利用http的重定向来跳转 window.location.replace("https://www.cnblogs.com/pythonywy/"); 2.原 ...

  6. React.js实现原生js拖拽效果及思考

    一.起因&思路 不知不觉,已经好几天没写博客了...近来除了研究React,还做了公司官网... 一直想写一个原生js拖拽效果,又加上近来学react学得比较嗨.所以就用react来实现这个拖 ...

  7. 如何创建一个客户端回调:js获得服务端的内容?

    答案:表面上看去就是前端的js调用服务的C#方法,本质就是ajax,通过XMLHttpRequest对象和服务端进行交互.回调:就说回过头来调用,按理说js是一种脚本语言,怎么能用来调用服务端的呢?就 ...

  8. 【原生js】原生js的省市区三级联动

    html: <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" c ...

  9. 用require.js封装原生js轮播图

    index.html页面: <!DOCTYPE html><html> <head> <meta charset="UTF-8"> ...

  10. 【原生js】原生js实现验证码短信发送倒计时

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

随机推荐

  1. java一般使用基础

    1.这是一个通用 仿制药javaA型安全机制来保护. 它是通过变量的类型,如果,实现变量类型限制,从而保证了程序编译变量类型的安全性在一定程度上.反之.如果没有泛型,这些只存在于程序,如果猿的大脑,这 ...

  2. ios swift学习日记1-Swift 初见

    最近ios的swift语言似乎火了,我没有objectc基金会,但在此之前有cjava的基础的.从这几天開始学习ios的swift语言.后期以博客形式公布.这里提供一本翻译的英文版的swif书籍. 还 ...

  3. Putty是一个专业的SSH连接客户端

    http://www.putty.ws/PuTTY-LinuxVPS Putty是一个专业的SSH连接客户端,当然可以用来连接Linux操作系统的VPS.下文是Putty连接工具的使用方法与详细教程, ...

  4. 异步编程和线程的使用(.NET 4.5 )

    C#:异步编程和线程的使用(.NET 4.5 )   异步编程和线程处理是并发或并行编程非常重要的功能特征.为了实现异步编程,可使用线程也可以不用.将异步与线程同时讲,将有助于我们更好的理解它们的特征 ...

  5. javascript系列之DOM(二)

    原文:javascript系列之DOM(二) 原生DOM扩展 我们接着第一部分来说,上文提到了两种常规的DOM操作:创建文档片段和遍历元素节点.我们知道那些雨后春笋般的库,有很大一部分工作就是提供了一 ...

  6. js isArray小结

    原文:[转载]js isArray小结 在日常开发中,我们经常需要判断某个对象是否是数组类型的,在js中检测对象类型的常见的方法有几种: 1.typeof操作符.对于Function.String.N ...

  7. wp如何代码实现锁屏

    原文:wp如何代码实现锁屏 由于wp系统对开发者相对封闭,造成了用户对那些稍有用处但又不那么有用的功能过度追求,比如说重启.锁屏等功能.针对一个功能写两行代码,再起一个牛逼哼哼的名字,就可以获得超级多 ...

  8. linux_UBUNTU 12.04 上使用 SQUID 架设HTTP正向代理服务器

    配置普通HTTP正向代理 安装   1 sudo apt-get install squid squid-common 配置 squid3   1 sudo vim /etc/squid3/squid ...

  9. 【转】UIAutomator定位Android控件的方法实践和建议(Appium姊妹篇)

    原文地址:http://blog.csdn.net/zhubaitian/article/details/39777951 在本人之前的一篇文章<<Appium基于安卓的各种FindEle ...

  10. C语言第11课

    主要内容:函数指针 一.函数指针定义 int  maxValue(int  a,int  b) { return   a > b ? a : b; } 函数名和数组名一样是地址,存在在代码区 i ...