前面的话

  简易日历作为javascript中Date对象的常见应用,用途较广泛。本文将详细说明简易日历的实现思路

效果演示

HTML说明

  使用type=number的两个input分别作为年和月的输入控件,这样在高级浏览器下自带调节按钮

  按照周日到周一的顺序进行星期的排列

<div class="box">
<header class='control'>
<input id="conYear" class="con-in" type="number" min="1900" max="2100" step="1"/>
<input id="conMonth" class="con-in" type="number" min="1" max="12" step="1"/>
</header>
<div class="DateBox">
<header class='week'>
<div class="week-in">周日</div>
<div class="week-in">周一</div>
<div class="week-in">周二</div>
<div class="week-in">周三</div>
<div class="week-in">周四</div>
<div class="week-in">周五</div>
<div class="week-in">周六</div>
</header>
<section class="dayBox" id='dayBox'>
<div class="day" id="day1">1</div>
<div class="day">2</div>
<div class="day">3</div>
<div class="day">4</div>
<div class="day">5</div>
<div class="day">6</div>
<div class="day">7</div>
<div class="day">8</div>
<div class="day">9</div>
<div class="day">10</div>
<div class="day">11</div>
<div class="day">12</div>
<div class="day">13</div>
<div class="day">14</div>
<div class="day">15</div>
<div class="day">16</div>
<div class="day">17</div>
<div class="day">18</div>
<div class="day">19</div>
<div class="day">20</div>
<div class="day">21</div>
<div class="day">22</div>
<div class="day">23</div>
<div class="day">24</div>
<div class="day">25</div>
<div class="day">26</div>
<div class="day">27</div>
<div class="day">28</div>
<div class="day">29</div>
<div class="day" id="day30">30</div>
<div class="day" id="day31">31</div>
</section>
</div>
</div>

CSS说明

  对于简易日历的实现,首先确定日历中class="day"的div的排列方式为浮动。这样可以通过改变第一天div的位置,来实现所有同级div都可以跟随移动的效果

body{
margin:;
}
input{
border: none;
padding:;
}
.box{
width: 354px;
margin: 30px auto 0;
}
.DateBox{
height: 300px;
border: 2px solid black;
}
.week{
overflow: hidden;
border-bottom: 1px solid black;
line-height: 49px;
}
.week-in{
height: 49px;
float: left;
width: 50px;
text-align: center;
}
.dayBox{
overflow: hidden;
}
.day{
float: left;
height: 50px;
width: 50px;
font:20px/50px '微软雅黑';
text-align: center;
}
.control{
overflow: hidden;
}
.con-in{
height: 50px;
float: left;
width: 100px;
text-align: center;
font: 20px/50px "微软雅黑";
}

JS说明

  简易日历的JS逻辑总共需要5个实现:

  【1】需要获取当月的天数,获取当月第一天、第30天、第31天是周几

  【2】根据当月第一天的星期,改变第一天的margin-left值,移动第一天到对应的位置;由于浮动的关系,其余天也会跟着移动到对应的位置

  【3】根据当月的天数,隐藏多余的天;当然,隐藏之前要先显示在其他月份可能被隐藏的天

  【4】如果当月30日是周日,则会新占一行。这时通过改变30日这天的margin值将其移动到第一行(若31日可能会新占一行,也做相似处理)

  【5】载入页面后,获取当前的年和月,显示当月日历;当改变年或月时,获取改变后的值,更新日历

//准备:获取当前样式
function getCSS(obj,style){
if(window.getComputedStyle){
return getComputedStyle(obj)[style];
}
return obj.currentStyle[style];
}
//实现一:获取当月的天数,及当月第一天、第30日、第31日是星期几
function get_data(year,month){
var result = {};
var d = new Date();
//如果是2月
if(month == 2){
//如果是闰年
if((year % 4 === 0 && year % 100 !== 0) || year % 400 === 0){
result.days = 29;
//如果是平年
}else{
result.days = 28;
}
//如果是第4、6、9、11月
}else if(month == 4 || month == 6 ||month == 9 ||month == 11){
result.days = 30;
}else{
result.days = 31;
//当月第31天是星期几
result.day31week = d.getDay(d.setFullYear(year,month-1,31));
}
//当月第一天是星期几
result.day1week = d.getDay(d.setFullYear(year,month-1,1));
if(month != 2){
//当月第30天是星期几
result.day30week = d.getDay(d.setFullYear(year,month-1,30));
}
return result;
}
//实现二:根据当月第一天的星期x,设置第一天的margin-left=宽度*x,使其对应到正确的星期位置上
function move_day1(year,month){
var week1 = get_data(year,month).day1week;
day1.style.marginLeft = week1%7*parseInt(getCSS(day1,'width'))+ 'px';
}
//实现三:根据当月的天数,来隐藏多余的天数。当然首先要先显示在其他月份被隐藏的天数
function hide_days(year,month){
//恢复其他月份可能隐藏的天数
for(var i = 28; i<31; i++){
dayBox.children[i].style.display = 'block';
}
//隐藏当月多余的天数
var days = get_data(year,month).days;
for(var i = days;i<31;i++){
dayBox.children[i].style.display = 'none';
}
};
//实现四:如果当月30日或31日是星期日,则会新占一行,通过设置margin-top把新占一行的天移动到第一行
function move_day30(year,month){
//如果当月30日是星期日
if(get_data(year,month).day30week === 0){
day30.style.marginTop = parseInt(getCSS(day30,'height')) *(-5) + 'px';
day31.style.marginTop = parseInt(getCSS(day31,'height')) *(-5) + 'px';
day31.style.marginLeft= getCSS(day31,'width');
return;
}else{
day30.style.marginTop = day31.style.marginTop = day31.style.marginLeft ='0';
}
//如果当月31日是星期日
if(get_data(year,month).day31week === 0){
day31.style.marginTop = parseInt(getCSS(day31,'height')) *(-5) + 'px';
}else{
day31.style.marginTop = '0';
}
}
//实现五:当载入页面时,获取当前年和月,显示当月日历;当改变年或月时,获取改变后的年和月,更新当月日历
var year= conYear.value=new Date().getFullYear();
var month= conMonth.value = new Date().getMonth() + 1;
move_day1(year,month);
hide_days(year,month);
move_day30(year,month); conYear.onchange = conMonth.onchange = function(){
var year = conYear.value;
var month = conMonth.value;
if(year<1900 || year >2100 ){
year = conYear.value=new Date().getFullYear();
}
if(month<1 || month > 12){
month = conMonth.value=new Date().getMonth() + 1;
}
move_day1(year,month);
hide_days(year,month);
move_day30(year,month);
}

javascript中Date对象的应用——简易日历的实现的更多相关文章

  1. javascript中Date对象的应用

    前面的话 简易日历作为javascript中Date对象的常见应用,用途较广泛.本文将详细说明简易日历的实现思路 效果演示 HTML说明 使用type=number的两个input分别作为年和月的输入 ...

  2. JavaScript中date 对象常用方法

    Date 对象 Date 对象用于处理日期和时间. //创建 Date 对象的语法: var datetime = new Date();//Date 对象会自动把当前日期和时间保存为其初始值. co ...

  3. Javascript中Date对象的格式化

    很多语言中都带有日期的格式化函数,而Javascript中却没有提供类似的方法.之前从某位前人的帖子中发现了下面的代码,感觉非常简洁,存留备用. /** * 时间对象的格式化; */ Date.pro ...

  4. javascript中Date对象复习

    js的Date对象不怎么经常用,所以忘得差不多,复习一下 1.声明一个Date对象,默认本地当前时间 var date = new Date();//Fri Apr 28 2017 14:26:19 ...

  5. JavaScript中判断对象类型方法大全1

    我们知道,JavaScript中检测对象类型的运算符有:typeof.instanceof,还有对象的constructor属性: 1) typeof 运算符 typeof 是一元运算符,返回结果是一 ...

  6. JavaScript中判断对象类型的种种方法

    我们知道,JavaScript中检测对象类型的运算符有:typeof.instanceof,还有对象的constructor属性: 1) typeof 运算符 typeof 是一元运算符,返回结果是一 ...

  7. 转 JavaScript中判断对象类型的种种方法

    我们知道,JavaScript中检测对象类型的运算符有:typeof.instanceof,还有对象的constructor属性: 1) typeof 运算符 typeof 是一元运算符,返回结果是一 ...

  8. js实现小时钟,js中Date对象的使用?

    介绍一下js中Date对象的使用 dateObj = new Date() dateObj = new Date(dateValue) dateObj = new Date(year,month,da ...

  9. JavaScript中的对象与原型—你不知道的JavaScript上卷读书笔记(四)

    一.对象 对象可以通过两种形式定义:声明(文字)形式和构造形式.即: var myObj = { key: value // ... }; 或: var myObj = new Object(); m ...

随机推荐

  1. 无法远程到2008R2的解决方法

    运维的一台Server,昨天还很正常,今天突然远程桌面无法登陆,提示“由于没有远程桌面授权服务器可以提供许可证,远程会话被中断.....”,开始以为是权限问题,试了很多方法,都无法解决,后来上网找解决 ...

  2. 自学日记--JavaScript 001

    1.1输出内容: document.write(); 1.2警告语句: alert(); 1.3确认语句: comfirm(str); 返回值:boolean  确认返回true  取消返回false ...

  3. Objective-C 关联

    在项目开发中,经常会使用到关联,就是将两个实例对象绑定,使得其中一个实例对象成为另一个实例对象的一部分.关联特性在mac os 10.6 及ios 3.1以上才可以使用. 关联的使用是基于关键字来实现 ...

  4. Adobe Flash Builder 4.7破解方法(绝对可用)

    Flash Builder4.7 破解方法的实践 建议:作为草根一级,买不起正版,只能先拿破解版练练手了,如果商业的话,请用正版.  具体步骤如下: 1.到Adobe官网下载FlashBuilder  ...

  5. Vagrant 启用 rsync

    折腾了那么久,发现这些smb,nfs,virtualcfs,这些同步方案在windows下都不是最完美的.最完美的还是 rsync,我使用它同步windows上的代码,在windows浏览器中打开虚拟 ...

  6. centos6 一个vlan配置多ip地址

    添加vlan [root@localhost network-scripts]# vconfig add eth1 109 配置文件,此处配置了vlan109使用子接口进行多ip配置: [root@l ...

  7. velocity整合servlet

    目录结构点我下载工程代码俩实体类不用说了看CustomerVelocityServlet类 package com.velocity.servlet;import java.util.ArrayLis ...

  8. 打造Ubuntu下Java开发环境

    一.了解JDK 不同的java软件和类库对jdk有不同要求,在了解如何安装Java之前,让我们快速地了解JRE.OpenJDK和Oracle JDK之间的不同之处. JRE(Java Runtime ...

  9. python 之readability与BeautifulSoup

    以前要采集某个网页,一般做法是写程序源代码爬出来,然后用正则去匹配出来,这种针对指定的网页去爬效果还可以,但是如果是批量的网页这种实现就会变得不现实,在这时候就有readability出手的意义了,r ...

  10. 如何自行处理写好的eclipse插件安装不生效

    本帖最后由 anrainie 于 2013-7-23 11:31 编辑 对于eclipse插件开发的新手,经常会遇到插件写好了,拷贝到plugins或dropins文件下,但是没有生效.上网各种问,也 ...