JavaScript实现简单日历
页面代码:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8">
<title>JavaScript Sample</title>
<style type="text/css">
div #dataTextContainer
{
border:1px #A5ACB2 solid;
width: 100px;
height: 19px;
text-align: right;
float:left;
}
div #dataTextContainer input
{
border-width: 0px;
border-style: none;
border-color: transparent;
width: 68px;
height: 14px;
font-size: 12px;
text-align: left;
}
div #dataTextContainer button
{
width: 22px;
height: 19px;
margin: 0px;
padding:0px;
text-align: center;
}
div #calendarContainer
{
width: 200px;
height: 100px;
z-index: 10000;
font-size: 13px;
}
</style>
<script type="text/javascript" src="inputDate.js"></script>
</head>
<body>
<div id = "dataTextContainer">
<input name="dataText" id="dateText" type="text" onfocus="javascript:getCurrentDay();"/>
<button onclick="javascript:displayCalendar();">
<img src="rili.jpg" width="15" height="12">
</button>
</div>
<div id="calendarContainer"></div>
</body>
</html>
Javascript代码:
function getCurrentDay()
{
var newDate = new Date;
var odate = document.getElementById("dateText");
var date_year = newDate.getFullYear();
var date_month = newDate.getMonth() + 1;
var date_today = newDate.getDate();
odate.value = date_year+"-"+date_month+"-"+date_today;
}
function displayCalendar()
{
drawCalendar();
}
function closeCalendar()
{
var oCalendarContainer = document.getElementById("calendarContainer");
oCalendarContainer.innerHTML = "";
}
function drawCalendar(sYear,sMonth)
{
var newDate;
if(arguments[0] == null || arguments[1] == null)
{
newDate = new Date();
}
else
{
newDate = new Date(sYear,sMonth - 1);
} var date_year = newDate.getFullYear();
var date_month = newDate.getMonth() + 1;
var date_today = newDate.getDate();
var date_day = newDate.getDay(); var nextMonth = date_month + 1;
var nextYear = date_year;
var prevMonth = date_month - 1;
var prevYear = date_year; if(sMonth == 12)
{
nextMonth = 1;
nextYear = date_year + 1;
}
if(sMonth == 1)
{
prevMonth = 12;
prevYear = date_year - 1;
} var calendarTable = "";
calendarTable += '<table width="200" border="0" cellpadding="0" cellspacing="0" style="background-color:#0066FF;text-align:center;">';
calendarTable += ' <tr style="background-color:#339999;">';
//向前翻年
calendarTable += '<td colspan="2" onclick="javascript:drawCalendar('+(prevYear - 1)+','+prevMonth+');"'+
' style="cursor:pointer;background-color:#FF6600;"><<<</td>';
//向前翻月
calendarTable += '<td colspan="2" onclick="javascript:drawCalendar('+prevYear+','+prevMonth+');"'+
' style="cursor:pointer;background-color:#FF6600;"><<</td>';
//向后翻月
calendarTable += '<td colspan="2" onclick="javascript:drawCalendar('+nextYear+','+nextMonth+');"'+
' style="cursor:pointer;background-color:#FF6600;">>></td>';
//向后翻年
calendarTable += '<td colspan="1" onclick="javascript:drawCalendar('+(nextYear + 1)+','+nextMonth+');"'+
' style="cursor:pointer;background-color:#FF6600;">>>></td>';
calendarTable += ' </tr>'; //星期表头
calendarTable += ' <tr style="background-color:#6699FF;">';
calendarTable += ' <td>日</td>';
calendarTable += ' <td>一</td>';
calendarTable += ' <td>二</td>';
calendarTable += ' <td>三</td>';
calendarTable += ' <td>四</td>';
calendarTable += ' <td>五</td>';
calendarTable += ' <td>六</td>';
calendarTable += ' </tr>'; //计算一个月内的天数,注意闰月
var dayNum_in_month = [31,28,31,30,31,30,31,31,30,31,30,31];
var isleapyear = date_year % 4;
if(isleapyear == 0)
{
dayNum_in_month[1] = 29;
}
var month_alldays = dayNum_in_month[date_month - 1]; //计算行数,line_top表示当前日期上面的行数,包含当前行;line_bot表示当前日期以下的行数,不包含当前行
var line_top;
var line_bot;
if((date_today - date_day + 1) % 7 != 0)
{
line_top = Math.floor((date_today - date_day + 1) / 7) + 1;
}
else
{
line_top = Math.floor((date_today - date_day + 1) / 7);
} if((30 - date_today + date_day + 1) % 7 != 0)
{
line_bot = Math.floor((30 - date_today + date_day + 1) / 7) + 1;
}
else
{
line_bot = Math.floor((30 - date_today + date_day + 1) / 7);
} //定义一个二维数组,预备一个6*7的数组,数组中每一个元素相应一个单元格(日期)
var dateList = new Array([""],[""],[""],[""],[""],[""],[""]);
var dateCell; for(var i = 1; i < 7; i++)
{
//i是行数
calendarTable += ' <tr>';
for(var j = 0; j < 7; j++)
{
//j是列数
dateList[i][j] = date_today - 7 * (line_top - i + 1) + j - date_day;
//假设武器<=0,置空
if((date_today - 7 * (line_top - i + 1) + j - date_day) <= 0)
{
dateList[i][j] = " ";
}
//假设日期大于月总天数,则不显示
if((date_today - 7 * (line_top - i + 1) + j - date_day) > month_alldays)
{
dateList[i][j] = " ";
} if(dateList[i][j] != " ")
{
//假设单元格不是空,那么能够设置其触发三个事件,共同拥有三个事件
//1、单击事件,将当前日期写入文本框
//2、鼠标指针移到单元格上,改变背景
//3、鼠标指针离开单元格,背景复原
dateCell =
'<td onclick="javascript:setDateText('+date_year+','+date_month+',this.firstChild.nodeValue);"'+'onmouseover="javascript:setFocus(this);"'+' onmouseout="javascript:setFocusOut(this);"'+ ' style="cursor:pointer;">'+dateList[i][j]+'</td>'; if(i == line_top && j == line_bot)
{
dateCell =
'<td onclick="javascript:setDateText('+date_year+','+date_month+',this.firstChild.nodeValue);"'+'onmouseover="javascript:setFocus(this);"'+' onmouseout="javascript:setFocusOut(this);"'+ ' style="cursor:pointer;background-color:#FF6600;">'+dateList[i][j]+'</td>';
}
}
else
{
dateCell = "<td> </td>";
}
calendarTable += dateCell;
}
calendarTable += '</tr>';
}
calendarTable += '<tr><td colspan="7"'+'onclick="javascript:closeCalendar();"'+'style="background-color#339999;cursor:pointer;color:red;font-weight:bold">'+'关闭('+date_year+"年"+date_month+"月"+')</td></tr>';
calendarTable += '</table>'; //将日期写入
var oCalendarContainer = document.getElementById("calendarContainer");
oCalendarContainer.innerHTML = calendarTable;
} //当鼠标指针指到当前日期单元格
function setFocus(obj)
{
obj.style.backgroundColor = "#FF6600";
}
//当鼠标指针离开当前日期单元格
function setFocusOut(obj)
{
obj.style.backgroundColor = "";
}
//鼠标单击当前单元格
function setDateText(sYear,sMonth,sDate)
{
var oDateText = document.getElementById("dateText");
oDateText.value = sYear + "-" + sMonth + "-" + sDate;
}
效果:>>下一月 >>>下一年 <<上一月 <<<上一年
JavaScript实现简单日历的更多相关文章
- js编写当天简单日历
之前一直很想用javascript写一个日历,但是因为完全没有好的思路, 所以迟迟没有尝试.最近在网上刚好看到用javascript编写的简单日历的例子,代码量虽然不大, 但是我觉得很好地阐述了js日 ...
- js超简单日历
用原生js写了一个超级简单的日历.当做是练习js中的Date类型. 思路: 获取某个日期,根据年份计算出每个月的天数. 利用Date中的getDay()知道该月份的第一天为星期几. 循环创建表格,显示 ...
- JavaScript设置简单的自动时间
下面就是一段简单的JavaScript设置简单的自动时间,时间显示在一个输入框input里面. <html> <head> </head> <body> ...
- Javascript的简单测试环境
在<JavaScript忍者秘籍>2.4测试条件基础知识中,作者给出了一个精简版的assert和assert组的实现,对于初学者而言,这无疑是一个很好的例子,既让我们得到了一个好用的小工具 ...
- javaScript(2)---简单使用
javaScript(2)---简单使用 学习要点: 1.创建一张HTML页面 2.<Script>标签解析 3.JS代码嵌入的一些问题 一.创建一张HTML页面 <!DOCTYPE ...
- Javascript学习-简单测试环境
Javascript学习-简单测试环境 在<JavaScript忍者秘籍>2.4测试条件基础知识中,作者给出了一个精简版的assert和assert组的实现,对于初学者而言,这无疑是一个很 ...
- JS写一个简单日历
JS写一个日历,配合jQuery操作DOM <!DOCTYPE html> <html> <head> <meta charset="UTF-8&q ...
- JavaScript中简单排序总结
JavaScript中简单排序总结 冒泡排序 经典排序算法, 双重for循环 在第二个for循环的时候, j < arr.len -1 -i , 这一步的优化很重要 function bullS ...
- JavaScript 实现简单的 弹出框关闭框
JavaScript 实现简单的 弹出框关闭框 知识点: 1.javaScript 添加HTML标签 2.javaScript 添加HTML标签属性 3.javaScript 追加元素 代码献上: & ...
随机推荐
- 2C 产品的本质是人性,2B 产品的背后是业务(转)
本文作者李源是 BLUES 原来做 YY 语音客户端产品时候的同事,原来针对 YY 语音的游戏用户做 2C 的 PC 客户端产品和 APP,后来到某品牌手机做 2B 的后台系统.以下文章,是作者经历了 ...
- Java 审查基调
1.& 与 &&的差别 两个都有逻辑与的功能. 可是所不同的是.当&两边的表达式不是boolean类型的时候,&具有位与的功能:&&是短路与,当 ...
- combobox自己主动提示组件加入无选中项清空功能
这个标题非常绕口,只是这也是想了半天的成果,对不起体育老师了. 标题想表达的是:之前讲过的用combobox实现自己主动提示组件.只是如今规定该组件不能够保存data中不存在的数据. 最初的想法是通过 ...
- 查询系统--基于Solr4.9.0实现
为什么非要搜索系统 随着在产品的数量的增长.和复杂的检索要求,直接从数据库中检索信息,它已经无法满足展示机搜索需求. 实例: keyword=%E8%8B%B9%E6%9E%9C&enc=ut ...
- or1200下Raw-OS学习(例子篇)
没有图我说个~毛(J)线(B)~对吧??? 直接上一个以前做过的项目来说说怎么去从一个前后台的程序过度到利用操作系统去管理的你代码吧~以前想过直接用事件驱动的框架去编写代码的,无奈这方面的资料实在太少 ...
- Java得到年在一个季度的错误的第一天
1.错误叙述性说明 Exception in thread "main" java.lang.IllegalArgumentException: Cannot format giv ...
- C# ^ 运算符和 || 运算符的区别
|| : 条件“或”,条件或运算符 (||) 执行的逻辑或其 bool 操作数. 如果第一个操作数计算结果为 true,第二个操作数对象不会计算. 如果第一个操作数计算结果为 false,第二个运算符 ...
- 淘宝异构数据源数据交换工具 DataX
淘宝异构数据源数据交换工具 DataX 阅读目录 DataX是什么? DataX用来解决什么? DataX特点? DataX结构模式(框架+插件) DataX在淘宝的运用 DataX是什么? Data ...
- ProgressDialog(三)——代号为中心的屏幕上显示ProgressDialog(ProgressBar)
MainActivity如下面: package cc.testprogressdialog; import android.os.Bundle; import android.view.Gravit ...
- RestServer 1.1发布
具体配置方法参照第一版:http://www.cnblogs.com/devgis/p/4947191.html BUG反馈 QQ:80163278 邮箱:devgis@qq.com 淘宝:http: ...