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 相关文章推荐
解决js数据包含加号+通过ajax传到后台时出现连接错误
Aug 01 Javascript
15条JavaScript最佳实践小结
Aug 09 Javascript
jQuery异步验证用户名是否存在示例代码
May 21 Javascript
ECMAScript 6即将带给我们新的数组操作方法前瞻
Jan 06 Javascript
BootStrap轻松实现微信页面开发代码分享
Oct 21 Javascript
Jquery Easyui对话框组件Dialog使用详解(14)
Dec 19 Javascript
Javascript中的 “&amp;” 和 “|” 详解
Feb 02 Javascript
ES6新特性之类(Class)和继承(Extends)相关概念与用法分析
May 24 Javascript
vue 组件中slot插口的具体用法
Apr 03 Javascript
Vue组件的使用及个人理解与介绍
Feb 09 Javascript
webpack中如何加载静态文件的方法步骤
May 18 Javascript
基于layui table返回的值的多级嵌套的解决方法
Sep 19 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添加Xdebug扩展的方法
2014/02/12 PHP
thinkphp使用literal防止模板标签被解析的方法
2014/11/22 PHP
php使用PDO从数据库表中读取数据的实现方法(必看)
2017/06/02 PHP
PHP自定义递归函数实现数组转JSON功能【支持GBK编码】
2018/07/17 PHP
ThinkPHP3.2.3框架实现的空模块、空控制器、空操作,跳转到错误404页面图文详解
2019/04/03 PHP
比较详细的关于javascript中void(0)的具体含义解释
2007/08/02 Javascript
jQuery学习笔记之控制页面实现代码
2012/02/27 Javascript
javascript五图轮播切换实用版
2012/08/17 Javascript
JQuery for与each性能比较分析
2013/05/14 Javascript
一个很有趣3D球状标签云兼容IE8
2014/08/22 Javascript
Ajax局部更新导致JS事件重复触发问题的解决方法
2014/10/14 Javascript
在easyUI开发中,出现jquery.easyui.min.js函数库问题的解决办法
2015/09/11 Javascript
js使用cookie记录用户名的方法
2015/11/26 Javascript
谈谈jQuery Ajax用法详解
2015/11/27 Javascript
如何利用模板将HTML从JavaScript中抽离
2016/10/08 Javascript
jQuery Easy UI中根据第一个下拉框选中的值设置第二个下拉框是否可以编辑
2016/11/29 Javascript
js使用Replace结合正则替换重复出现的字符串功能示例
2016/12/27 Javascript
VUE + UEditor 单图片跨域上传功能的实现方法
2018/02/08 Javascript
详解Vue 项目中的几个实用组件(ts)
2019/10/29 Javascript
浅析Python中的多重继承
2015/04/28 Python
Python记录详细调用堆栈日志的方法
2015/05/05 Python
Python操作列表之List.insert()方法的使用
2015/05/20 Python
python基础知识小结之集合
2015/11/25 Python
Python 常用模块 re 使用方法详解
2019/06/06 Python
python 利用jinja2模板生成html代码实例
2019/10/10 Python
Python json模块与jsonpath模块区别详解
2020/03/05 Python
Python爬虫实现百度翻译功能过程详解
2020/05/29 Python
python爬虫 requests-html的使用
2020/11/30 Python
日本著名的服饰鞋帽综合类购物网站:MAGASEEK
2019/01/09 全球购物
美国气象仪器、花园装饰和墙壁艺术商店:Wind & Weather
2019/05/29 全球购物
AJax面试题
2014/11/25 面试题
预防煤气中毒方案
2014/06/16 职场文书
劳模先进事迹材料
2014/12/24 职场文书
光荣之路观后感
2015/06/12 职场文书
redis客户端实现高可用读写分离的方式详解
2021/07/04 Redis
详解CSS中的特指度和层叠问题
2021/07/15 HTML / CSS