JS简单实现移动端日历功能示例


Posted in Javascript onDecember 28, 2016

本文实例讲述了JS简单实现移动端日历功能。分享给大家供大家参考,具体如下:

只是一个初步的简单的日历,有是否显示上月和下月部分的选项

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0">
  <meta name="apple-mobile-web-app-capable" content="yes">
  <meta name="apple-mobile-web-app-status-bar-style" content="black">
  <meta name = "format-detection" content = "telephone=no">
  <title>移动端日历</title>
  <style type="text/css">
    table{
      width: 100%;
      border-collapse: collapse;
    }
    td {
      padding: 0;
      margin: 0;
      vertical-align: middle;
      text-align: center;
      font-size: .7rem;
      height: 1.5rem;
    }
    .none{
      display: none;
    }
  </style>
</head>
<body>
  <div class="calendar">
    <table class="calendar_day">
      <tr>
        <td>星期日</td>
        <td>星期一</td>
        <td>星期二</td>
        <td>星期三</td>
        <td>星期四</td>
        <td>星期五</td>
        <td>星期六</td>
      </tr>
    </table>
    <table class="calendar_date">
      <tr>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
      </tr>
      <tr>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
      </tr>
      <tr>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
      </tr>
      <tr>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
      </tr>
      <tr>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
      </tr>
      <tr>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
      </tr>
    </table>
  </div>
  <script type="text/javascript">
  var date = new Date();
  calendar(date,{lastandnext:true})
  function calendar (setDate,options){
    if (!options) {
      options = {};
    }
    options.lastandnext = options.lastandnext || false;
    // 星期几部分
    var calendar_days = document.getElementsByClassName('calendar_day')[0];
    var days = calendar_days.getElementsByTagName('td');
    var date = new Date(setDate);
    var y = date.getFullYear();
    var m = date.getMonth();
    var d = date.getDate();
    // 本月
    // 该月的第一天是星期几
    var firstDay = new Date(y,m,1).getDay();
    // console.log(firstDay);
    // 该月一共多少天
    var lastData = new Date(y,m+1,0).getDate();
    // console.log(lastData)
    // 该月的最后一天是星期几
    var lastDay = new Date(y,m+1,0).getDay();
    // console.log(firstDay)
    var calendar_date = document.getElementsByClassName('calendar_date')[0];
    var tds = calendar_date.getElementsByTagName('td');
    // console.log(tds)
    var ed = firstDay;
    for (var i = firstDay; i < lastData+firstDay; i++) {
      // console.log(i-firstDay+1)
      tds[i].innerHTML= i-(firstDay)+1;
    }
    if(options.lastandnext){
      // // 上月
      var lastMonthData = new Date(y,m,0).getDate();
      for(var i = firstDay-1; i >= 0; i--){
        tds[i].innerHTML= lastMonthData-(firstDay-i-1);
      }
      // 下月
      var k = 0;
      for(var i = lastData+firstDay; i < tds.length; i++){
        k++;
        tds[i].innerHTML= k;
      }
    }
  }
  </script>
  <!-- 适配 -->
  <script type="text/javascript">
    ;(function(win, doc){
      function change(){
        doc.documentElement.style.fontSize=20*doc.documentElement.clientWidth/360+'px';
      }
      change();
      win.addEventListener('resize', change, false);
    })(window, document);
  </script>
</body>
</html>

PS:这里再为大家分享几款本站的在线日期工具供大家参考:

在线万年历日历:
http://tools.3water.com/bianmin/wannianli

网页万年历日历:
http://tools.3water.com/bianmin/webwannianli

在线万年历黄历flash版:
http://tools.3water.com/bianmin/flashwnl

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
广告切换效果(缓动切换)
May 27 Javascript
javascript 用记忆函数快速计算递归函数
Mar 15 Javascript
关于this和self的使用说明
Aug 01 Javascript
jquery键盘事件介绍
Jan 31 Javascript
用Javascript评估用户输入密码的强度实现代码
Nov 30 Javascript
使用控制台破解百小度一个月只准改一次名字
Aug 13 Javascript
nginx部署访问vue-cli搭建的项目的方法
Feb 12 Javascript
js实现删除li标签一行内容
Apr 16 Javascript
压缩Vue.js打包后的体积方法总结(Vue.js打包后体积过大问题)
Feb 03 Javascript
原生js实现分页效果
Sep 23 Javascript
JS前端轻量fabric.js系列之画布初始化
Aug 05 Javascript
如何学JavaScript?前辈的经验之谈
Dec 28 #Javascript
js+div+css下拉导航菜单完整代码分享
Dec 28 #Javascript
javascript实现简单的ajax封装示例
Dec 28 #Javascript
前端面试知识点锦集(JavaScript篇)
Dec 28 #Javascript
一句jQuery代码实现返回顶部效果(简单实用)
Dec 28 #Javascript
Web前端框架bootstrap实战【第一次接触使用】
Dec 28 #Javascript
hovertree插件实现二级树形菜单(简单实用)
Dec 28 #Javascript
You might like
php登陆页的密码处理方式分享
2013/10/14 PHP
PHP类的特性实例分析
2016/09/28 PHP
php版微信小店API二次开发及使用示例
2016/11/12 PHP
PHP 图片合成、仿微信群头像的方法示例
2019/10/25 PHP
jQuery中json对象的复制方式介绍(数组及对象)
2013/06/08 Javascript
Javascript实现禁止输入中文或英文的例子
2014/12/09 Javascript
javascript数组去重方法汇总
2015/04/23 Javascript
jQuery对JSON数据进行排序输出的方法
2015/06/24 Javascript
js实现仿百度风云榜可重复多次调用的TAB切换选项卡效果
2015/08/31 Javascript
JavaScript中Number对象的toFixed() 方法详解
2016/09/02 Javascript
Javascript 动态改变imput type属性
2016/11/01 Javascript
利用jqprint插件打印页面内容的实现方法
2018/01/09 Javascript
vue单页应用在页面刷新时保留状态数据的方法
2018/09/21 Javascript
深入理解js A*寻路算法原理与具体实现过程
2018/12/13 Javascript
Vue数组响应式操作及高阶函数使用代码详解
2020/08/01 Javascript
nuxt 路由、过渡特效、中间件的实现代码
2020/11/06 Javascript
[01:00:10]完美世界DOTA2联赛PWL S2 FTD vs Inki 第二场 11.21
2020/11/24 DOTA
[37:45]完美世界DOTA2联赛PWL S3 LBZS vs Phoenix 第二场 12.09
2020/12/11 DOTA
python的id()函数解密过程
2012/12/25 Python
Python实现从url中提取域名的几种方法
2014/09/26 Python
Python实现单词拼写检查
2015/04/25 Python
使用Python生成url短链接的方法
2015/05/04 Python
Python使用Beautiful Soup包编写爬虫时的一些关键点
2016/01/20 Python
火车票抢票python代码公开揭秘!
2018/03/08 Python
python高效过滤出文件夹下指定文件名结尾的文件实例
2018/10/21 Python
Python 按字典dict的键排序,并取出相应的键值放于list中的实例
2019/02/12 Python
Python使用mongodb保存爬取豆瓣电影的数据过程解析
2019/08/14 Python
Python django框架开发发布会签到系统(web开发)
2020/02/12 Python
德国排名第一的主题公园门票网站:Attraction Tickets Direct
2019/09/09 全球购物
英国珠宝和手表专家:Pleasance & Harper
2020/10/21 全球购物
应聘收银员个人的求职信
2013/11/30 职场文书
求职简历中个人的自我评价
2013/12/01 职场文书
公司培训心得体会
2014/01/03 职场文书
2014年大学生四年规划书范文
2014/04/03 职场文书
授权委托书样本
2014/04/03 职场文书
实习协议书范本
2014/09/25 职场文书