JS实现日历表

简介: JS实现日历表


有需要的可以用一下,这是一个简单的demo.


HTML:


<table>
    <thead>
    <tr>
      <th colspan="2">
      <span class="left">«</span>
      </th>
      <th colspan="3">
      <span class="time"></span>
      </th>
      <th colspan="2"><span class="right">»</span>
      </th>
    </tr>
    <tr>
      <th>日</th>
      <th>一</th>
      <th>二</th>
      <th>三</th>
      <th>四</th>
      <th>五</th>
      <th>六</th>
    </tr>
    </thead>
    <tbody class="main">
    </tbody>
  </table>


CSS:


<style>
    table {
    width: 320px;
    background: #ffffff;
    color: #000000;
    }
    td,
    th {
    text-align: center;
    height: 30px;
    }
  </style>

JS:


<script>
    var oTime = document.querySelector(".time") //头部年月标题显示
    var oMain = document.querySelector(".main") //主体日历数字显示
    var leftBtn = document.querySelector(".left"); //点击左边的按钮,月份减少
    var rightBtn = document.querySelector(".right"); //点击右边的按钮,月份增加
    var time = new Date(); //获取当前系统时间
    leftBtn.onclick = function() {
    time.setMonth(time.getMonth() - 1);
    getPrevDays(time);
    getCurrentDays(time);
    minHead(time);
    mainList(time, getPrevDays(time), getCurrentDays(time));
    }
    rightBtn.onclick = function() {
    time.setMonth(time.getMonth() + 1);
    getPrevDays(time);
    getCurrentDays(time);
    minHead(time);
    mainList(time, getPrevDays(time), getCurrentDays(time));
    }
    function minHead(time) {
    oTime.innerText = time.getFullYear() + "年" + (time.getMonth() + 1) + "月"
    }
    function mainList(time, prevDays, currentDays) {
    var beforeCount = prevDays.length + currentDays.length;
    var cellList = document.querySelectorAll("td");
    for (var i = 0; i < prevDays.length; i++) { //上一个月所占格子
      cellList[i].innerHTML = "<font color='#D3D5DA'>" + prevDays[i] + "</font>"
    }
    for (var i = 0; i < currentDays.length; i++) { //当前月所占格子
      if (currentDays[i] == time.getDate()) { //当天日期高亮显示
      cellList[i + prevDays.length].innerHTML = "<font color='blue'>" + currentDays[i] + "</font>";
      } else { //当月日期白色突出
      cellList[i + prevDays.length].innerHTML = "<font color='#000000'>" + currentDays[i] + "</font>";
      }
    }
    for (var i = 1; i <= (42 - beforeCount); i++) { //下个月所占格子
      cellList[i + beforeCount - 1].innerHTML = "<font color='#D3D5DA'>" + i + "</font>"
    }
    }
    function createCells() {
    for (var i = 0; i < 6; i++) { //6行
      var oTr = document.createElement("tr");
      for (var j = 0; j < 7; j++) { //7列
      var oTd = document.createElement("td");
      oTr.appendChild(oTd);
      }
      oMain.appendChild(oTr);
    }
    }
    function getPrevDays(time) { //获得上一个在本月所占的天数
    var time = new Date(time); //拷贝一份时间,避免时间修改发生冲突
    var list = []; //上一个月所占的天数
    time.setDate(1); //设置成当月1号,便于查看是星期几;
    var day = time.getDay() == 0 ? 7 : time.getDay(); //如果是0,说明数字第一行需要空出来放上一个月的时间
    //获取上一个月的天数
    time.setDate(0); //系统自动计算到上一个月的最后一天
    var maxDay = time.getDate(); //得到上一个月的最后一天时间
    for (var i = maxDay; i > (maxDay - day); i--) {
      //根据maxDay和day之间的关系,把上一个月的时间放到list中
      list.push(i);
    }
    list.reverse(); //日期升序排列
    return list;
    }
    function getCurrentDays(time) { //获取当前月的天数
    var time = new Date(time); //拷贝时间,原因同上
    time.setDate(1); //确保不会出现跨越现象  如果当前时间是1月31号就会出现跨越到三月份的事情
    var list = [];
    //下面代码是为了获取上一个月的天数
    time.setMonth(time.getMonth() + 1) //修改时间到下一个月
    time.setDate(0); //修改时间日期是0
    var maxDay = time.getDate();
    //获取到上一个月的日期并放到数组中
    for (var i = 1; i <= maxDay; i++) {
      list.push(i);
    }
    return list;
    }
    createCells(); //创建6行7列表格
    getPrevDays(time); //获取上一个月在当前月所占的格子数
    getCurrentDays(time); //获取当前月所占的格子数
    minHead(time); //显示头部标题
    mainList(time, getPrevDays(time), getCurrentDays(time)); //显示主题日历
  </script>


相关文章
|
6月前
|
缓存 前端开发 算法
Next.js
Next.js【8月更文挑战第4天】
102 1
|
6月前
|
JavaScript 前端开发
浅谈js。。
浅谈js。。
26 0
|
8月前
|
JavaScript 安全 前端开发
JS神奇的或0(|0)
可以看到明显的带或0运算与不带或0运算的结果无论是位数还是符号位都有不同。 那这中间到底发生了什么? 这里找一个数字为例:117063531626496 要想验证这个问题,思路如下: 1,对比变更前后的数字的二进制格式 2,找到是否有数字表示的安全边界 首先按照思路1,我们看一下这个数字和这个数字或0后的二进制格式分别是什么:
|
9月前
|
编解码 JavaScript 前端开发
js一些理解
js一些理解
47 1
|
9月前
|
JavaScript 前端开发 Go
octokit.js
octokit.js
66 1
|
9月前
|
JavaScript 前端开发
初识JS
这篇内容介绍了JavaScript的基础知识,包括DOM和BOM(相当于内置模块和第三方模块)、变量的声明(var、let、const的特点和区别)、数组操作(如push、pop、splice等)、字典操作以及DOM操作示例。变量部分强调了var的变量提升和块级作用域问题,let和const的块级作用域和不可重复声明,以及const用于创建不可变的常量。在实际应用中,展示了如何动态改变HTML元素内容和创建新元素的示例。
|
JavaScript
metainfo.js
metainfo.js
109 1
|
编解码 JavaScript 前端开发
什么是js?(初步了解)
什么是js?(初步了解)
|
JavaScript 前端开发
JS、JQuery基础题(下)
JS、JQuery基础题(下)
|
JavaScript
js超实用的小技巧(1)
js超实用的小技巧(1)