JavaScript实现简单日历效果


Posted in Javascript onSeptember 11, 2020

本文实例为大家分享了JavaScript实现简单日历效果的具体代码,供大家参考,具体内容如下

实现效果:

根据所选择的年月,列出当月对应是周几,效果图如下:

JavaScript实现简单日历效果

实现思路:

1、使用select标签保存年月的所选菜单。使用table标签保存当月天数,表头为固定的周日周一等。

2、使用option对象,给年月循环赋值。

3、将每月的天数保存到数组中,根据所选的年月获取当月的天数,以及当月一号对应周几,对应周几就在第一行先打印几个空格,然后从一号开始依次打印当月天数。

4、刷新年月时,清除上次表格中(除表头的周)的数据,重新填入数据。

代码实现:

<!DOCTYPE html>
<html>
 <head>
 <meta charset="UTF-8">
 <title></title>
 <!--CSS样式-->
 <style type="text/css">
 *{margin: 0px;padding: 0px;}
 #div{width: 400px;height: 300px;border: 1px solid red;margin: auto;}
 #div div:nth-child(1){display: flex;align-items: center;justify-content: center;}
 #tbcal{border-collapse: collapse;width: 100%;text-align: center;}
 #tbcal tr td{border: 1px solid red;}
 </style>
 <script type="text/javascript">
// 加载完HTML内容后,JavaScript开始执行
 window.onload=function(){
 initial();
 document.getElementById("selyear").onchange=show;
 document.getElementById("selmonth").onchange=show;
 show();
 }
// 显示日历
 function show(){
// 获取鼠标点击所选择的年月值
 var year=parseInt(document.getElementById("selyear").value);
 var month=parseInt(document.getElementById("selmonth").value);
// 判断是否为闰年,以便确定2月的天数
 var flag=year%4==0&&year%100!=0||year%400==0;
 var dayofmonth=[31,flag?29:28,31,30,31,30,31,31,30,31,30,31];
// 给date赋值,值为所选择的某年某月一号
 var dt=new Date();
 dt.setFullYear(year);
 dt.setMonth(month-1);
 dt.setDate(1);
// 获取date对应周几
 var week=dt.getDay();
// 当月应该打印多少行
 var rows=Math.ceil((dayofmonth[dt.getMonth()]+week)/7);
 var k=0;
// 如果表格中有除表头外的数据,进行数据删除,避免上次月份的数据对下次有影响
 var table=document.getElementById("tbcal");
 while(table.rows.length>1){
  table.deleteRow(1);
  
 }
// 循环向表格中添加数据,生成日历
 for(var i=0;i<rows;i++){
  var row=table.insertRow(i+1);
  for(var j=0;j<7;j++){
  var cell=row.insertCell(j);
  k++;
  if(k<=week || k>dayofmonth[dt.getMonth()]+week){
  cell.innerHTML="";
  }
  else{
  cell.innerHTML=k-week;
  }
  }
 }
 }
// 通过option对象向年月中循环赋值
 function initial(){
 var years=document.getElementById("selyear");
 var months=document.getElementById("selmonth");
 for (var i=1990;i<2019;i++) {
  var option=document.createElement("option");
  option.text=i;
  years.add(option);
 }
 for (var i=1;i<13;i++) {
  var option=document.createElement("option");
  option.text=i;
  months.add(option);
 }
 }
 </script>
 </head>
 <body>
 <div id="div">
 <!--定义年月菜单-->
 <div>
 <select id="selyear"></select> 年 
 <select id="selmonth"></select> 月 
 </div>
 <div>
 <!--定义列表-->
 <table id="tbcal">
  <tr>
  <td>周日</td>
  <td>周一</td>
  <td>周二</td>
  <td>周三</td>
  <td>周四</td>
  <td>周五</td>
  <td>周六</td>
  </tr>
 </table>
 </div>
 </div>
 </body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Jquery Ajax.ashx 高效分页实现代码
Oct 20 Javascript
js弹出层之1:JQuery.Boxy (二)
Oct 06 Javascript
深入浅析JavaScript中的Function类型
Jul 09 Javascript
一个仿微博登陆邮箱提示框js开发案例
Jul 28 Javascript
js闭包用法实例详解
Dec 13 Javascript
Webpack中css-loader和less-loader的使用教程
Apr 27 Javascript
详解vue服务端渲染浏览器端缓存(keep-alive)
Oct 12 Javascript
layui表单验证select下拉框实现验证的方法
Sep 05 Javascript
关于vue组件事件属性穿透详解
Oct 28 Javascript
p5.js绘制创意自画像
Nov 04 Javascript
小程序开发之模态框组件封装
Apr 23 Javascript
vue中使用vue-pdf的方法详解
Sep 05 Javascript
vue $mount 和 el的区别说明
Sep 11 #Javascript
JavaScript 判断数据类型的4种方法
Sep 11 #Javascript
jQuery实现日历效果
Sep 11 #jQuery
JS实现密码框效果
Sep 10 #Javascript
JavaScript常用工具函数库汇总
Sep 17 #Javascript
el-form 多层级表单的实现示例
Sep 10 #Javascript
详解React的回调渲染模式
Sep 10 #Javascript
You might like
用PHP即时捕捉PHP中的错误并发送email通知的实现代码
2013/01/19 PHP
php将12小时制转换成24小时制的方法
2015/03/31 PHP
php设计模式之原型模式分析【星际争霸游戏案例】
2020/03/23 PHP
通过继承IHttpHandle实现JS插件的组织与管理
2010/07/13 Javascript
Node.js实战 建立简单的Web服务器
2012/03/08 Javascript
IE8对JS通过属性和数组遍历解析不一样的地方探讨
2013/05/06 Javascript
js添加select下默认的option的value和text的方法
2014/10/19 Javascript
node.js中的favicon.ico请求问题处理
2014/12/15 Javascript
JavaScript实现数字数组正序排列的方法
2015/04/06 Javascript
JS+JSP通过img标签调用实现静态页面访问次数统计的方法
2015/12/14 Javascript
详解ECMAScript6入门--Class对象
2017/04/27 Javascript
jQuery实现select下拉框获取当前选中文本、值、索引
2017/05/08 jQuery
原生js实现密码输入框值的显示隐藏
2017/07/17 Javascript
JavaScript中的回调函数实例讲解
2019/01/27 Javascript
JS数组降维的实现Array.prototype.concat.apply([], arr)
2020/04/28 Javascript
Django中实现一个高性能计数器(Counter)实例
2014/07/09 Python
Python实现的简单模板引擎功能示例
2017/09/02 Python
ubuntu 16.04下python版本切换的方法
2019/06/14 Python
Python使用matplotlib 模块scatter方法画散点图示例
2019/09/27 Python
在TensorFlow中屏蔽warning的方式
2020/02/04 Python
Python抓新型冠状病毒肺炎疫情数据并绘制全国疫情分布的代码实例
2020/02/05 Python
解决使用python print打印函数返回值多一个None的问题
2020/04/09 Python
python中用ggplot绘制画图实例讲解
2021/01/26 Python
纯css3实现的竖形无限级导航
2014/12/10 HTML / CSS
欧缇丽加拿大官方网站:Caudalie加拿大
2019/07/18 全球购物
DELPHI中如何调用API,可举例说明
2014/01/16 面试题
数控技术专业推荐信
2013/11/01 职场文书
优秀班干部事迹材料
2014/01/26 职场文书
交通事故赔偿协议书
2014/04/15 职场文书
组工干部演讲稿
2014/09/02 职场文书
群众路线教育实践活动对照检查材料
2014/09/22 职场文书
2014年党的群众路线整改措施思想汇报
2014/10/12 职场文书
荒岛余生观后感
2015/06/09 职场文书
为了顺利买到演唱会的票用Python制作了自动抢票的脚本
2021/10/16 Python
世界十大评分最高的动漫,CLANNAD上榜,第八赚足人们眼泪
2022/03/18 日漫
golang语言指针操作
2022/04/14 Golang