js实现简单日历效果

 更新时间:2021年05月18日 08:35:26   作者:睡个好觉_  
这篇文章主要为大家详细介绍了js实现简单日历效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

## css模块
<style type="text/css">
  *{
   margin: 0;
   padding: 0;
  }
  .date{
   width: 300px;
   height: 220px;
   border: 1px solid #000;
   margin: 100px auto;
  }
  .title{
   width: 200px;
   display: flex;
   font-size: 12px;
   margin: auto;
   text-align: center;
   justify-content: space-around;
   align-items: center;
  }
  .year{
   margin: 0 40px;
   display: flex;
   flex-direction: column;
  }
  #week{
   border-top: 1px solid #000;
   border-bottom: 1px solid #000;
   margin: auto;
   list-style-type: none;
   display: flex;
  }
  #week li{
   display: inline-block;
   text-align: center;
   flex:1;
  }
  #ul{
   list-style-type: none;
   margin-top: 5px;
  }
  #ul li {
   display: inline-block;
   width: 40px;
   height: 21px;
   text-align: center;
   border: 1px solid #fff;
  }
  .current{
   color:red;
  }
  #ul li:hover{
   border: 1px solid red;
  }
  #prev,#next{
   cursor: pointer;
  }
 </style>

## html
<div class="date">
  <div class="title">
   <span id="prev">&lt;上一月</span>
   <div class="year">
    <span id="year">2021</span>
    <span id="month">5月</span>
   </div>
   <span id="next">下一月&gt;</span>
  </div>
  <!-- 用ul做日历 -->
  <ul id="week">
   <li>日</li>
   <li>一</li>
   <li>二</li>
   <li>三</li>
   <li>四</li>
   <li>五</li>
   <li>六</li>
  </ul>
  <ul id="ul">
   
  </ul>
</div>
## js代码
<script type="text/javascript">
  // date对象,方便切换月份,所以设置为全局对向
  let date = new Date();
  // 点击切换月份的事件
  document.getElementById('prev').addEventListener('click',function(){
   date.setMonth(date.getMonth()-1);
   add();
  })
  document.getElementById('next').addEventListener('click',function(){
   date.setMonth(date.getMonth()+1);
   add();
  })
  add();
  
  //制作日历的函数
  function add(){
   // 当前年
   let cYear = date.getFullYear();
   // 当前月
   let cMonth = date.getMonth()+1;
   // 获取到当前日期
   let cDay = date.getDate();
   
   // 写入年月
   document.getElementById('year').innerHTML = cYear;
   document.getElementById('month').innerHTML = cMonth+'月';
   
   
   let days = new Date(cYear,cMonth,-1);
   // 当前月份的天数
   let n = days.getDate()+1;
   // 每个月的第一天是星期几
   let week = new Date(cYear,cMonth-1,1).getDay();
   let html = '';
   // 写入dom
   for(let i=0;i<week;i++){
    html+=`<li></li>`
   }
   for(let i=1;i<=n;i++){
    if(i==cDay){
     html+=`<li class="current">${i}</li>`
    }else{
     html+=`<li>${i}</li>`
    }
   }
   // 一次性插入
   document.getElementById('ul').innerHTML = html
  }
</script>

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

相关文章

  • 用javascript添加控件自定义属性解析

    用javascript添加控件自定义属性解析

    这篇文章主要是对用javascript添加控件自定义属性进行了介绍,需要的朋友可以过来参考下,希望对大家有所帮助
    2013-11-11
  • p5.js入门教程和基本形状绘制

    p5.js入门教程和基本形状绘制

    本篇文章主要介绍了p5.js入门教程之简介和基本形状绘制,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-03-03
  • 详解ECMAScript typeof用法

    详解ECMAScript typeof用法

    typeof 返回变量的类型字符串值 、其中包括 “object”、“number”、“string”、“undefined”、“boolean”。这篇文章重点给大家介绍ECMAScript typeof用法,需要的朋友参考下
    2018-07-07
  • 微信小程序movable-view的可移动范围示例详解

    微信小程序movable-view的可移动范围示例详解

    这篇文章主要介绍了微信小程序movable-view的可移动范围 ,movable-view不管怎么移动都要完全包含住movable-area,也就是说movable-area不能超出movable-view的区域范围,反之亦然,本文通过示例介绍的非常详细,需要的朋友可以参考下
    2022-07-07
  • js方法数据验证的简单实例

    js方法数据验证的简单实例

    下面小编就为大家带来一篇js方法数据验证的简单实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-09-09
  • 纯前端使用插件pdfjs实现将pdf转为图片的步骤

    纯前端使用插件pdfjs实现将pdf转为图片的步骤

    这篇文章主要介绍了纯前端使用插件pdfjs实现将pdf转为图片的步骤,在实现过程中遇到了跨域问题,后台设置跨域但前端配置无效,最终采用后台返回PDF的base64格式,通过PDF.js将base64转换为二进制数据加载PDF,需要的朋友可以参考下
    2025-01-01
  • onmousewheel event 缩放图片效果

    onmousewheel event 缩放图片效果

    onmousewheel event 缩放图片效果...
    2006-09-09
  • 手把手教你如何开发属于自己的一款小程序

    手把手教你如何开发属于自己的一款小程序

    相信大家都知道小程序是一种不需要下载安装即可使用的应用,下面这篇文章主要给大家介绍了关于如何开发属于自己的一款小程序的相关资料,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2023-01-01
  • JS判断鼠标进入容器的方向与window.open新窗口被拦截的问题

    JS判断鼠标进入容器的方向与window.open新窗口被拦截的问题

    这篇文章主要给大家介绍了利用Javascript判断鼠标进入容器方向的方法,以及window.open新窗口被拦截的问题分析,文中给出了详细图文介绍和示例代码,相信对大家的理解和学习具有一定的参考借鉴价值,下面来一起看看吧。
    2016-12-12
  • 微信小程序swiper实现文字纵向轮播提示效果

    微信小程序swiper实现文字纵向轮播提示效果

    这篇文章主要介绍了微信小程序swiper实现文字纵向轮播提示效果,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-01-01

最新评论