asp.net千奇百怪的日历【月儿原创】
发布日期:2021-06-30 19:16:11 浏览次数:2 分类:技术文章

本文共 31326 字,大约阅读时间需要 104 分钟。

asp.net千奇百怪的日历

作者:清清月儿

主页:           时间:2007.5.14

日历控件是我们经常使用的,本文把常用的几款日历总结如下。 

1.下拉日历梅花雨版第1款

点评:最经典的几乎完美了。

代码:

<%
@ Page Language="C#" AutoEventWireup="true"  CodeFile="Default.aspx.cs" Inherits="_Default" 
%>
<
html  
>
<
head 
runat
="server"
>
    
<
title
>
日历控件
</
title
>
<
script 
type
="text/javascript"
 src
="calendar.js"
></
script
>
</
head
>
<
body
>
    
<
form 
id
="form1"
 runat
="server"
>
    
<
div
>
        
        
<
input 
id
="Text1"
 type
="text"
  onFocus
=calendar() 
/>
       
</
div
>
    
</
form
>
</
body
>
</
html
>

<!--
document.write(
"
<div id=meizzCalendarLayer style='position: absolute; z-index: 9999; width: 144; height: 193; display: none'>
"
);
document.write(
"
<iframe name=meizzCalendarIframe scrolling=no frameborder=0 width=100% height=100%></iframe></div>
"
);
function
 writeIframe()
{
    
var strIframe = "<html><head><meta http-equiv='Content-Type' content='text/html; charset=gb2312'><style>"+
    
"*{font-size: 12px; font-family: 宋体}"+
    
".bg{  color: "+ WebCalendar.lightColor +"; cursor: default; background-color: "+ WebCalendar.darkColor +";}"+
    
"table#tableMain{ width: 142; height: 180;}"+
    
"table#tableWeek td{ color: "+ WebCalendar.lightColor +";}"+
    
"table#tableDay  td{ font-weight: bold;}"+
    
"td#meizzYearHead, td#meizzYearMonth{color: "+ parent.WebCalendar.wordColor +"}"+
    
".out { text-align: center; border-top: 1px solid "+ WebCalendar.DarkBorder +"; border-left: 1px solid "+ WebCalendar.DarkBorder +";"+
    
"border-right: 1px solid "+ WebCalendar.lightColor +"; border-bottom: 1px solid "+ WebCalendar.lightColor +";}"+
    
".over{ text-align: center; border-top: 1px solid #FFFFFF; border-left: 1px solid #FFFFFF;"+
    
"border-bottom: 1px solid "+ WebCalendar.DarkBorder +"; border-right: 1px solid "+ WebCalendar.DarkBorder +"}"+
    
"input{ border: 1px solid "+ WebCalendar.darkColor +"; padding-top: 1px; height: 18; cursor: hand;"+
    
"       color:"+ WebCalendar.wordColor +"; background-color: "+ WebCalendar.btnBgColor +"}"+
    
"</style></head><body onselectstart='return false' style='margin: 0px' οncοntextmenu='return false'><form name=meizz>";
    
if (WebCalendar.drag){ strIframe += "<scr"+"ipt language=javascript>"+
    
"var drag=false, cx=0, cy=0, o = parent.WebCalendar.calendar; function document.onmousemove(){
"+
    
"if(parent.WebCalendar.drag && drag){if(o.style.left=='')o.style.left=0; if(o.style.top=='')o.style.top=0;"+
    
"o.style.left = parseInt(o.style.left) + window.event.clientX-cx;"+
    
"o.style.top  = parseInt(o.style.top)  + window.event.clientY-cy;}}"+
    
"function document.onkeydown(){ switch(window.event.keyCode){  case 27 : parent.hiddenCalendar(); break;"+
    
"case 37 : parent.prevM(); break; case 38 : parent.prevY(); break; case 39 : parent.nextM(); break; case 40 : parent.nextY(); break;"+
    
"case 84 : document.forms[0].today.click(); break;} window.event.keyCode = 0; window.event.returnValue= false;}"+
    
"function dragStart(){cx=window.event.clientX; cy=window.event.clientY; drag=true;}</scr"+"ipt>"}
    strIframe 
+= "<select name=tmpYearSelect  οnblur='parent.hiddenSelect(this)' style='z-index:1;position:absolute;top:3;left:18;display:none'"+
    
" οnchange='parent.WebCalendar.thisYear =this.value; parent.hiddenSelect(this); parent.writeCalendar();'></select>"+
    
"<select name=tmpMonthSelect οnblur='parent.hiddenSelect(this)' style='z-index:1; position:absolute;top:3;left:74;display:none'"+
    
" οnchange='parent.WebCalendar.thisMonth=this.value; parent.hiddenSelect(this); parent.writeCalendar();'></select>"+
    
"<table id=tableMain class=bg border=0 cellspacing=2 cellpadding=0>"+
    
"<tr><td width=140 height=19 bgcolor='"+ WebCalendar.lightColor +"'>"+
    
"    <table width=140 id=tableHead border=0 cellspacing=1 cellpadding=0><tr align=center>"+
    
"    <td width=15 height=19 class=bg title='向前翻 1 月&#13;快捷键:←' style='cursor: hand' οnclick='parent.prevM()'><b>&lt;</b></td>"+
    
"    <td width=60 id=meizzYearHead  title='点击此处选择年份' οnclick='parent.funYearSelect(parseInt(this.innerText, 10))'"+
    
"        οnmοuseοver='this.bgColor=parent.WebCalendar.darkColor; this.style.color=parent.WebCalendar.lightColor'"+
    
"        οnmοuseοut='this.bgColor=parent.WebCalendar.lightColor; this.style.color=parent.WebCalendar.wordColor'></td>"+
    
"    <td width=50 id=meizzYearMonth title='点击此处选择月份' οnclick='parent.funMonthSelect(parseInt(this.innerText, 10))'"+
    
"        οnmοuseοver='this.bgColor=parent.WebCalendar.darkColor; this.style.color=parent.WebCalendar.lightColor'"+
    
"        οnmοuseοut='this.bgColor=parent.WebCalendar.lightColor; this.style.color=parent.WebCalendar.wordColor'></td>"+
    
"    <td width=15 class=bg title='向后翻 1 月&#13;快捷键:→' οnclick='parent.nextM()' style='cursor: hand'><b>&gt;</b></td></tr></table>"+
    
"</td></tr><tr><td height=20><table id=tableWeek border=1 width=140 cellpadding=0 cellspacing=0 ";
    
if(WebCalendar.drag){strIframe += "οnmοusedοwn='dragStart()' οnmοuseup='drag=false' οnmοuseοut='drag=false'";}
    strIframe 
+= " borderColorLight='"+ WebCalendar.darkColor +"' borderColorDark='"+ WebCalendar.lightColor +"'>"+
    
"    <tr align=center><td height=20>日</td><td>一</td><td>二</td><td>三</td><td>四</td><td>五</td><td>六</td></tr></table>"+
    
"</td></tr><tr><td valign=top width=140 bgcolor='"+ WebCalendar.lightColor +"'>"+
    
"    <table id=tableDay height=120 width=140 border=0 cellspacing=1 cellpadding=0>";
         
for(var x=0; x<5; x++){ strIframe += "<tr>";
         
for(var y=0; y<7; y++)  strIframe += "<td class=out id='meizzDay"+ (x*7+y) +"'></td>"; strIframe += "</tr>";}
         strIframe 
+= "<tr>";
         
for(var x=35; x<39; x++) strIframe += "<td class=out id='meizzDay"+ x +"'></td>";
         strIframe 
+="<td colspan=3 class=out title='"+ WebCalendar.regInfo +"'><input style=' background-color: "+
         WebCalendar.btnBgColor 
+";cursor: hand; padding-top: 4px; width: 100%; height: 100%; border: 0' οnfοcus='this.blur()'"+
         
" type=button value='&nbsp; &nbsp; 关闭' οnclick='parent.hiddenCalendar()'></td></tr></table>"+
    
"</td></tr><tr><td height=20 width=140 bgcolor='"+ WebCalendar.lightColor +"'>"+
    
"    <table border=0 cellpadding=1 cellspacing=0 width=140>"+
    
"    <tr><td><input name=prevYear title='向前翻 1 年&#13;快捷键:↑' οnclick='parent.prevY()' type=button value='&lt;&lt;'"+
    
"    οnfοcus='this.blur()' style='meizz:expression(this.disabled=parent.WebCalendar.thisYear==1000)'><input"+
    
"    οnfοcus='this.blur()' name=prevMonth title='向前翻 1 月&#13;快捷键:←' οnclick='parent.prevM()' type=button value='&lt;&nbsp;'>"+
    
"    </td><td align=center><input name=today type=button value='Today' οnfοcus='this.blur()' style='width: 50' title='当前日期&#13;快捷键:T'"+
    
"    οnclick="parent.returnDate(new Date().getDate() +'/'+ (new Date().getMonth() +1) +'/'+ new Date().getFullYear())">"+
    
"    </td><td align=right><input title='向后翻 1 月&#13;快捷键:→' name=nextMonth οnclick='parent.nextM()' type=button value='&nbsp;&gt;'"+
    
"    οnfοcus='this.blur()'><input name=nextYear title='向后翻 1 年&#13;快捷键:↓' οnclick='parent.nextY()' type=button value='&gt;&gt;'"+
    
"    οnfοcus='this.blur()' style='meizz:expression(this.disabled=parent.WebCalendar.thisYear==9999)'></td></tr></table>"+
    
"</td></tr><table></form></body></html>";
    
with(WebCalendar.iframe)
    
{
        document.writeln(strIframe); document.close();
        
for(var i=0; i<39; i++)
        
{
            WebCalendar.dayObj[i] 
= eval("meizzDay"+ i);
            WebCalendar.dayObj[i].onmouseover 
= dayMouseOver;
            WebCalendar.dayObj[i].onmouseout  
= dayMouseOut;
            WebCalendar.dayObj[i].onclick     
= returnDate;
        }
    }
}
function
 WebCalendar() 
//
初始化日历的设置
{
    
this.regInfo    = "关闭的快捷键:[Esc]";
    
this.daysMonth  = new Array(312831303130313130313031);
    
this.day        = new Array(39);            //定义日历展示用的数组
    this.dayObj     = new Array(39);            //定义日期展示控件数组
    this.dateStyle  = null;                     //保存格式化后日期数组
    this.objExport  = null;                     //日历回传的显示控件
    
this.eventSrc   = null;                     //日历显示的触发控件
    
this.inputDate  = null;                     //转化外的输入的日期(d/m/yyyy)
    this.thisYear   = new Date().getFullYear(); //定义年的变量的初始值
    
this.thisMonth  = new Date().getMonth()+ 1//定义月的变量的初始值
    
this.thisDay    = new Date().getDate();     //定义日的变量的初始值
    
this.today      = this.thisDay +"/"+ this.thisMonth +"/"+ this.thisYear;   //今天(d/m/yyyy)
    this.iframe     = window.frames("meizzCalendarIframe"); //日历的 iframe 载体
    this.calendar   = getObjectById("meizzCalendarLayer");  //日历的层
    this.dateReg    = "";           //日历格式验证的正则式
    this.yearFall   = 50;           //定义年下拉框的年差值
    
this.format     = "yyyy-mm-dd"//回传日期的格式
    
this.timeShow   = false;        //是否返回时间
    this.drag       = true;         //是否允许拖动
    this.darkColor  = "#0000D0";    //控件的暗色
    
this.lightColor = "#FFFFFF";    //控件的亮色
    
this.btnBgColor = "#E6E6FA";    //控件的按钮背景色
    this.wordColor  = "#000080";    //控件的文字颜色
    
this.wordDark   = "#DCDCDC";    //控件的暗文字颜色
    this.dayBgColor = "#F5F5FA";    //日期数字背景色
    
this.todayColor = "#FF0000";    //今天在日历上的标示背景色
    this.DarkBorder = "#D4D0C8";    //日期显示的立体表达色
}
   
var
 WebCalendar 
=
 
new
 WebCalendar();
function
 calendar() 
//
主调函数
{
    
var e = window.event.srcElement;   writeIframe();
    
var o = WebCalendar.calendar.style; WebCalendar.eventSrc = e;
 
if (arguments.length == 0) WebCalendar.objExport = e;
    
else WebCalendar.objExport = eval(arguments[0]);
    WebCalendar.iframe.tableWeek.style.cursor 
= WebCalendar.drag ? "move" : "default";
 
var t = e.offsetTop,  h = e.clientHeight, l = e.offsetLeft, p = e.type;
 
while (e = e.offsetParent){t += e.offsetTop; l += e.offsetLeft;}
    o.display 
= ""; WebCalendar.iframe.document.body.focus();
    
var cw = WebCalendar.calendar.clientWidth, ch = WebCalendar.calendar.clientHeight;
    
var dw = document.body.clientWidth, dl = document.body.scrollLeft, dt = document.body.scrollTop;
    
    
if (document.body.clientHeight + dt - t - h >= ch) o.top = (p=="image")? t + h : t + h + 6;
    
else o.top  = (t - dt < ch) ? ((p=="image")? t + h : t + h + 6) : t - ch;
    
if (dw + dl - l >= cw) o.left = l; else o.left = (dw >= cw) ? dw - cw + dl : dl;
    
if  (!WebCalendar.timeShow) WebCalendar.dateReg = /^(d{
1,4}
)(-|/)(d{
1,2}
)2(d{
1,2}
)$/;
    
else WebCalendar.dateReg = /^(d{
1,4}
)(-|/)(d{
1,2}
)2(d{
1,2}
) (d{
1,2}
):(d{
1,2}
):(d{
1,2}
)$/;
    
try{
        
if (WebCalendar.objExport.value.trim() != ""){
            WebCalendar.dateStyle 
= WebCalendar.objExport.value.trim().match(WebCalendar.dateReg);
            
if (WebCalendar.dateStyle == null)
            
{
                WebCalendar.thisYear   
= new Date().getFullYear();
                WebCalendar.thisMonth  
= new Date().getMonth()+ 1;
                WebCalendar.thisDay    
= new Date().getDate();
                alert(
"原文本框里的日期有错误!可能与你定义的显示时分秒有冲突!");
                writeCalendar(); 
return false;
            }
            
else
            
{
                WebCalendar.thisYear   
= parseInt(WebCalendar.dateStyle[1], 10);
                WebCalendar.thisMonth  
= parseInt(WebCalendar.dateStyle[3], 10);
                WebCalendar.thisDay    
= parseInt(WebCalendar.dateStyle[4], 10);
                WebCalendar.inputDate  
= parseInt(WebCalendar.thisDay, 10+"/"+ parseInt(WebCalendar.thisMonth, 10+"/"+ 
                parseInt(WebCalendar.thisYear, 
10); writeCalendar();
            }
        }
  else writeCalendar();
    }
  catch(e){writeCalendar();}
}
function
 funMonthSelect() 
//
月份的下拉框
{
    
var m = isNaN(parseInt(WebCalendar.thisMonth, 10)) ? new Date().getMonth() + 1 : parseInt(WebCalendar.thisMonth);
    
var e = WebCalendar.iframe.document.forms[0].tmpMonthSelect;
    
for (var i=1; i<13; i++) e.options.add(new Option(i +"", i));
    e.style.display 
= ""; e.value = m; e.focus(); window.status = e.style.top;
}
function
 funYearSelect() 
//
年份的下拉框
{
    
var n = WebCalendar.yearFall;
    
var e = WebCalendar.iframe.document.forms[0].tmpYearSelect;
    
var y = isNaN(parseInt(WebCalendar.thisYear, 10)) ? new Date().getFullYear() : parseInt(WebCalendar.thisYear);
        y 
= (y <= 100)? 100 : ((y >= 2050)? 2050 : y);
    
var min = (y - n >= 100? y - n : 100;
    
var max = (y + n <= 2050? y + n : 2050;
        min 
= (max == 2050? max-n*2 : min;
        max 
= (min == 100? min+n*2 : max;
    
for (var i=min; i<=max; i++) e.options.add(new Option(i +"", i));
    e.style.display 
= ""; e.value = y; e.focus();
}
function
 prevM()  
//
往前翻月份
{
    WebCalendar.thisDay 
= 1;
    
if (WebCalendar.thisMonth==1)
    
{
        WebCalendar.thisYear
--;
        WebCalendar.thisMonth
=13;
    }
    WebCalendar.thisMonth
--; writeCalendar();
}
function
 nextM()  
//
往后翻月份
{
    WebCalendar.thisDay 
= 1;
    
if (WebCalendar.thisMonth==12)
    
{
        WebCalendar.thisYear
++;
        WebCalendar.thisMonth
=0;
    }
    WebCalendar.thisMonth
++; writeCalendar();
}
function
 prevY()
{WebCalendar.thisDay = 1; WebCalendar.thisYear--; writeCalendar();}
//
往前翻 Year
function
 nextY()
{WebCalendar.thisDay = 1; WebCalendar.thisYear++; writeCalendar();}
//
往后翻 Year
function
 hiddenSelect(e)
{
for(var i=e.options.length; i>-1; i--)e.options.remove(i); e.style.display="none";}
function
 getObjectById(id)
if(document.all) return(eval("document.all."+ id)); return(eval(id)); }
function
 hiddenCalendar()
{getObjectById("meizzCalendarLayer").style.display = "none";}
;
function
 appendZero(n)
{
return(("00"+ n).substr(("00"+ n).length-2));}
//
日期自动补零程序
function
 String.prototype.trim()
{
return this.replace(/(^s*)|(s*$)/g,"");}
function
 dayMouseOver()
{
    
this.className = "over";
    
this.style.backgroundColor = WebCalendar.darkColor;
    
if(WebCalendar.day[this.id.substr(8)].split("/")[1== WebCalendar.thisMonth)
    
this.style.color = WebCalendar.lightColor;
}
function
 dayMouseOut()
{
    
this.className = "out"var d = WebCalendar.day[this.id.substr(8)], a = d.split("/");
    
this.style.removeAttribute('backgroundColor');
    
if(a[1== WebCalendar.thisMonth && d != WebCalendar.today)
    
{
        
if(WebCalendar.dateStyle && a[0== parseInt(WebCalendar.dateStyle[4], 10))
        
this.style.color = WebCalendar.lightColor;
        
this.style.color = WebCalendar.wordColor;
    }
}
function
 writeCalendar() 
//
对日历显示的数据的处理程序
{
    
var y = WebCalendar.thisYear;
    
var m = WebCalendar.thisMonth; 
    
var d = WebCalendar.thisDay;
    WebCalendar.daysMonth[
1= (0==y%4 && (y%100!=0 || y%400==0)) ? 29 : 28;
    
if (!(y<=9999 && y >= 1000 && parseInt(m, 10)>0 && parseInt(m, 10)<13 && parseInt(d, 10)>0)){
        alert(
"对不起,你输入了错误的日期!");
        WebCalendar.thisYear   
= new Date().getFullYear();
        WebCalendar.thisMonth  
= new Date().getMonth()+ 1;
        WebCalendar.thisDay    
= new Date().getDate(); }
    y 
= WebCalendar.thisYear;
    m 
= WebCalendar.thisMonth;
    d 
= WebCalendar.thisDay;
    WebCalendar.iframe.meizzYearHead.innerText  
= y +" 年";
    WebCalendar.iframe.meizzYearMonth.innerText 
= parseInt(m, 10+" 月";
    WebCalendar.daysMonth[
1= (0==y%4 && (y%100!=0 || y%400==0)) ? 29 : 28//闰年二月为29天
    
var w = new Date(y, m-11).getDay();
    
var prevDays = m==1  ? WebCalendar.daysMonth[11] : WebCalendar.daysMonth[m-2];
    
for(var i=(w-1); i>=0; i--//这三个 for 循环为日历赋数据源(数组 WebCalendar.day)格式是 d/m/yyyy
    {
        WebCalendar.day[i] 
= prevDays +"/"+ (parseInt(m, 10)-1+"/"+ y;
        
if(m==1) WebCalendar.day[i] = prevDays +"/"+ 12 +"/"+ (parseInt(y, 10)-1);
        prevDays
--;
    }
    
for(var i=1; i<=WebCalendar.daysMonth[m-1]; i++) WebCalendar.day[i+w-1= i +"/"+ m +"/"+ y;
    
for(var i=1; i<39-w-WebCalendar.daysMonth[m-1]+1; i++)
    
{
        WebCalendar.day[WebCalendar.daysMonth[m
-1]+w-1+i] = i +"/"+ (parseInt(m, 10)+1+"/"+ y;
        
if(m==12) WebCalendar.day[WebCalendar.daysMonth[m-1]+w-1+i] = i +"/"+ 1 +"/"+ (parseInt(y, 10)+1);
    }
    
for(var i=0; i<39; i++)    //这个循环是根据源数组写到日历里显示
    
{
        
var a = WebCalendar.day[i].split("/");
        WebCalendar.dayObj[i].innerText    
= a[0];
        WebCalendar.dayObj[i].title        
= a[2+"-"+ appendZero(a[1]) +"-"+ appendZero(a[0]);
        WebCalendar.dayObj[i].bgColor      
= WebCalendar.dayBgColor;
        WebCalendar.dayObj[i].style.color  
= WebCalendar.wordColor;
        
if ((i<10 && parseInt(WebCalendar.day[i], 10)>20|| (i>27 && parseInt(WebCalendar.day[i], 10)<12))
            WebCalendar.dayObj[i].style.color 
= WebCalendar.wordDark;
        
if (WebCalendar.inputDate==WebCalendar.day[i])    //设置输入框里的日期在日历上的颜色
        {WebCalendar.dayObj[i].bgColor = WebCalendar.darkColor; WebCalendar.dayObj[i].style.color = WebCalendar.lightColor;}
        
if (WebCalendar.day[i] == WebCalendar.today)      //设置今天在日历上反应出来的颜色
        
{WebCalendar.dayObj[i].bgColor = WebCalendar.todayColor; WebCalendar.dayObj[i].style.color = WebCalendar.lightColor;}
    }
}
function
 returnDate() 
//
根据日期格式等返回用户选定的日期
{
    
if(WebCalendar.objExport)
    
{
        
var returnValue;
        
var a = (arguments.length==0? WebCalendar.day[this.id.substr(8)].split("/") : arguments[0].split("/");
        
var d = WebCalendar.format.match(/^(w{
4}
)(-|/)(w{
1,2}
)2(w{
1,2}
)$/);
        
if(d==null){alert("你设定的日期输出格式不对! 请重新定义 WebCalendar.format !"); return false;}
        
var flag = d[3].length==2 || d[4].length==2//判断返回的日期格式是否要补零
        returnValue = flag ? a[2+d[2]+ appendZero(a[1]) +d[2]+ appendZero(a[0]) : a[2+d[2]+ a[1+d[2]+ a[0];
        
if(WebCalendar.timeShow)
        
{
            
var h = new Date().getHours(), m = new Date().getMinutes(), s = new Date().getSeconds();
            returnValue 
+= flag ? " "+ appendZero(h) +":"+ appendZero(m) +":"+ appendZero(s) : " "+  h  +":"+ m +":"+ s;
        }
        WebCalendar.objExport.value 
= returnValue;
        hiddenCalendar();
    }
}
function
 document.onclick()
{
    
if(WebCalendar.eventSrc != window.event.srcElement) hiddenCalendar();
}
//
-->

calendar.js 注意存为带签名的utf-8

梅花雨版第2款
点评:
比上一款大些,色彩淡一点。

 

<%
@ Page Language="C#" AutoEventWireup="true" CodeFile="Default2.aspx.cs" Inherits="Default2" 
%>
<
html
>
<
head 
runat
="server"
>
    
<
title
>
日历控件
</
title
>
    
<
script 
type
="text/javascript"
 src
="calendar.js"
></
script
>
</
head
>
<
body
>
    
<
form 
id
="form1"
 runat
="server"
>
    
<
div
>
    
<
input 
onfocus
="setday(this);"
 name
="Calendar1"
 type
="text"
 id
="Calendar1"
  
/>
    
</
div
>
    
</
form
>
</
body
>
</
html
>

calendar.js

 2.万年历
点评:可以自定义节日,是很多系统里做装饰的

 

 

<%
@ Page Language="C#" AutoEventWireup="true"  CodeFile="Default.aspx.cs" Inherits="_Default" 
%>
<
html
>
<
head 
runat
="server"
>
    
<
title
>
日历控件
</
title
>
<
script 
type
="text/javascript"
 src
="wnl.js"
></
script
>
<
SCRIPT 
language
=JavaScript
>
function click() 
{
if (event.button==2{alert('欢迎访问——农历与西历对照') }
}
document.onmousedown
=click
</
SCRIPT
>
<
STYLE
>
.todyaColor {
    BACKGROUND-COLOR
: aqua
}
</
STYLE
>
</
head
>
<
BODY 
leftMargin
=5 
topMargin
=1 
onload
=initial()
>
<
SCRIPT 
language
=JavaScript
>
<!--
   
if(navigator.appName == "Netscape" || parseInt(navigator.appVersion) < 4)
   document.write(
"<h1>你的浏览器无法执行此程序。</h1>此程序在 IE4 以后的版本才能执行!!")
//--></SCRIPT>
<DIV id=detail style="POSITION: absolute"></DIV>
<CENTER>
<FORM name=CLD>
<TABLE>
  
<TBODY>
  
<TR>
    
<TD align=middle>
      
<DIV style="Z-INDEX: -1; POSITION: absolute; TOP: 30px"><FONT id=YMBG 
      style
="FONT-SIZE: 80pt; COLOR: #e0e0e0; FONT-FAMILY: 'Arial Black'"><BR>JUN</FONT> 
      
</DIV>
      
<TABLE border=0>
        
<TBODY>
        
<TR>
          
<TD bgColor=#00ffff colSpan=7><FONT style="FONT-SIZE: 9pt" 
            color
=#333333 size=2>西历 <SELECT style="FONT-SIZE: 9pt" 
            onchange
=changeCld() name=SY> 
              
<SCRIPT language=JavaScript><!--
            
for(i=1900;i<2050;i++) document.write('<option>'+i)
            
//--></SCRIPT>
            </SELECT>年 <SELECT style="FONT-SIZE: 9pt" onchange=changeCld() 
            name
=SM> 
              
<SCRIPT language=JavaScript><!--
            
for(i=1;i<13;i++) document.write('<option>'+i)
            
//--></SCRIPT>
            </SELECT>月 </FONT><FONT id=GZ face=宋体 color=#333333 
            size
=4></FONT><BR></TD></TR>
        
<TR align=middle bgColor=#e0e0e0>
          
<TD width=54></TD>
          
<TD width=54></TD>
          
<TD width=54></TD>
          
<TD width=50></TD>
          
<TD width=54></TD>
          
<TD width=54></TD>
          
<TD width=54></TD></TR>
        
<SCRIPT language=JavaScript><!--
            
var gNum
            
for(i=0;i<6;i++
            
{
               document.write(
'<tr align=center>')
               
for(j=0;j<7;j++
               
{
                  gNum 
= i*7+j
                  document.write(
'<td id="GD' + gNum +'" onMouseOver="mOvr(' + gNum +')" onMouseOut="mOut()"><font id="SD' + gNum +'" size=5 face="Arial Black"')
                  
if(j == 0) document.write(' color=red')
                  
if(j == 6)
                    
if(i%2==1) document.write(' color=red')
                    
else document.write(' color=green')
                  document.write(
' TITLE=""> </font><br><font id="LD' + gNum + '" size=2 style="font-size:9pt"> </font></td>')
               }
               document.write(
'</tr>')
            }
            
//--></SCRIPT>
        </TBODY></TABLE></TD>
    
<TD vAlign=top align=middle width=60><BR><BR><BR><BR><BUTTON 
      style
="FONT-SIZE: 9pt" onclick="pushBtm('YD')">年↑</BUTTON><BR><BUTTON 
      style
="FONT-SIZE: 9pt" onclick="pushBtm('YU')">年↓</BUTTON> 
      
<P><BUTTON style="FONT-SIZE: 9pt" 
      onclick
="pushBtm('MD')">月↑</BUTTON><BR><BUTTON style="FONT-SIZE: 9pt" 
      onclick
="pushBtm('MU')">月↓</BUTTON> </P>
      
<P><BUTTON style="FONT-SIZE: 9pt" onclick="pushBtm('')">当月</BUTTON> </P>
      
<P><INPUT style="FONT-SIZE: 9pt" onclick="javascript: window.close()" type=button value=关闭> 
      
</P></TD></TR></TBODY></TABLE></FORM></CENTER></BODY>
</html>

 wnl.js

 3.Flash日历

点评:可切换时钟日历2种状态,不过可惜不能选择,只能看而已,似乎作者没有写版权,好想其拉类似的都写个版权。

日历状态:

时间状态:

clock.swf

4.仿Windows风格系统时间和日历
点评:
没有和textbox结合

仿系统日历和时间钟.htm

5.仿Windows风格系统时间和日历

点评:和textbox结合

 

<
HTML
><
HEAD
><
TITLE
>
http://blog.csdn.net/21aspnet/
</
TITLE
>
<
META 
http-equiv
=Content-Type 
content
="text/html; charset=utf-8"
>
<
META 
content
="MSHTML 6.00.3790.0"
 name
=GENERATOR
>
<
META 
content
=C# 
name
=CODE_LANGUAGE
>
<
META 
content
=JavaScript 
name
=vs_defaultClientScript
>
<
META 
content
=http://schemas.microsoft.com/intellisense/ie5 
name
=vs_targetSchema
>
<
script 
lanuage
='javascript'
>
        
function Calendar(obj)
        
{
            
var showx = event.screenX - event.offsetX - 4 - 
210 ; // + deltaX;
            var showy = event.screenY - event.offsetY + 18
// + deltaY;
            var newWINwidth = 210 + 4 + 18;
            
            
    
            
var retval = window.showModalDialog
(
'cal.htm',obj.value, 
'dialogWidth:206px;dialogHeight:221px;dialogLeft:'+showx+'px; 
dialogTop:
'+showy+'px;status:0;help:0;scroll:0');
            
if( retval != null )
            
{
                obj.value 
= retval;
            }
    
        }
        
</
script
>
</
HEAD
>
<
BODY 
bgColor
=white 
leftMargin
=0 
topMargin
=0
>
<
FORM 
id
=Form1 
name
=Form1 
action
=Search.aspx 
method
=post
>
<
input 
name
="tbGreateTime"
 type
="text"
 value
=""
 id
="tbGreateTime"
 
readonly
="true"
 onclick
="javascript:Calendar(this);"
 
style
="width:70px;cursor:hand;"
 
/>
</
body
>
</
html
>

 

6.当前时间

 

<!
DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
>
<
html
>
<
head
>
<
meta 
http-equiv
="Content-Type"
 content
="text/html; charset=gb2312"
>
<
title
>
时钟
</
title
>
<
script 
language
="VBScript"
>
<!--
sub show_time()
frmclock.txtDate.value
=date()
frmclock.txtTime.value
=time()
settimeout
"show_time",1000
end sub
-->
</
script
>
</
head
>
<
body 
onLoad
=show_time()
>
<
form 
name
="frmClock"
 
>
  
<
font 
size
="2"
>
今天是: 
  
<
input 
type
="text"
 name
="txtDate"
 value
=""
>
  
<
br
>
  时间是:
</
font
><
font 
size
="2"
>
  
  
<
input 
type
="text"
 name
="txtTime"
 value
=""
>
        
</
font
></
form
>
</
body
>
</
html
>

7.动态版权

做网站很多时候要写版权的时间。

 

<
SCRIPT
>
document.write(
"
1999-
"
+
(
new
 Date()).getYear())
</
SCRIPT
>

 

8.最常用最短小精悍的日历

<!
DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
>
<
html
>
<
head
>
<
meta 
http-equiv
="Content-Type"
 content
="text/html; charset=gb2312"
>
<
title
>
每天日历
</
title
>
</
head
>
<
body
>
<
script 
language
="JavaScript"
 type
="text/JavaScript"
>
var day="";
var month="";
var ampm="";
var ampmhour="";
var myweekday="";
var year="";
mydate
=new Date();
myweekday
=mydate.getDay();
mymonth
=mydate.getMonth()+1;
myday
= mydate.getDate();
myyear
= mydate.getYear();
year
=(myyear > 200? myyear : 1900 + myyear;
if(myweekday == 0)
weekday
=" 星期日 ";
else if(myweekday == 1)
weekday
=" 星期一 ";
else if(myweekday == 2)
weekday
=" 星期二 ";
else if(myweekday == 3)
weekday
=" 星期三 ";
else if(myweekday == 4)
weekday
=" 星期四 ";
else if(myweekday == 5)
weekday
=" 星期五 ";
else if(myweekday == 6)
weekday
=" 星期六 ";
document.write(year
+""+mymonth+""+myday+"日 "+weekday);
</
script
>
</
body
>
</
html
>
9.下拉日历
<
form
>
<
select 
id
=year 
onchange
=toDate()
>
<
script
>
for(i=1970;i<=2010;i++)document.write("<option>"+i+"</option>")
</
script
>
</
select
>
<
select 
id
=month 
onchange
=toDate()
>
<
script
>
for(i=1;i<=12;i++)document.write("<option>"+i+"</option>")
</
script
>
</
select
>
<
select 
id
=day 
onchange
=toDay()
></
select
>
<
input 
name
=weekday
>
</
form
>
<
script
>
var arr="日一二三四五六".split("")
function toDate(){
    
with(document.all){
        vYear
=parseInt(year.options[year.selectedIndex].text)
        vMonth
=parseInt(month.options[month.selectedIndex].text)
        day.length
=0;
        
for(i=0;i<(new Date(vYear,vMonth,0)).getDate();i++){day.options[day.length++].value=day.length;day.options[day.length-1].text=day.length;}
    }
    toDay();
}
function toDay(){
    vDay
=parseInt(document.all.day.options[document.all.day.selectedIndex].value)
    document.all(
"weekday").value="星期"+arr[new Date(vYear,vMonth-1,vDay).getDay()]
}
window.onload
=toDate;
</
script
>
10.农历
<
script 
language
="JavaScript"
>
<!--
function CalConv()
 
{
 FIRSTYEAR 
= 1998;
 LASTYEAR 
= 2031;
 today 
= new Date();
 SolarYear 
= today.getFullYear();
 SolarMonth 
= today.getMonth() + 1;
 SolarDate 
= today.getDate();
 Weekday 
= today.getDay();
 LunarCal 
= [
  
new tagLunarCal( 27,  53431001001101101 ),
  
new tagLunarCal( 46,  04481001001011101 ), /* 88 */
  
new tagLunarCal( 35,  05531100100101101 ), /* 89 */
  
new tagLunarCal( 23,  40591101010010101 ),
  
new tagLunarCal( 42,  01,  41101010010101 ),
  
new tagLunarCal( 31,  02,  91101101001010 ),
  
new tagLunarCal( 21,  23140101101010101 ), /* 93 */
  
new tagLunarCal( 39,  05200101011010101 ),
  
new tagLunarCal( 28,  76251010101011011 ),
  
new tagLunarCal( 48,  00300010010111011 ),
  
new tagLunarCal( 37,  01351001001011011 ), /* 97 */
  
new tagLunarCal( 25,  53411100100101011 ),
  
new tagLunarCal( 44,  04461010100101011 ),
  
new tagLunarCal( 33,  05511011010010101 ),
  
new tagLunarCal( 22,  46561011010101010 ), /* 101 */
  
new tagLunarCal( 40,  01,  21011010101010 ),
  
new tagLunarCal( 30,  92,  70101010110101 ),
  
new tagLunarCal( 49,  03120100101110101 ),
  
new tagLunarCal( 38,  04171010010110110 ), /* 105 */
  
new tagLunarCal( 27,  66230101001010111 ),
  
new tagLunarCal( 46,  00280101001010110 ),
  
new tagLunarCal( 35,  01330110100100110 ),
  
new tagLunarCal( 24,  42380111010010101 ), /* 109 */
  
new tagLunarCal( 42,  04440110101010101 ),
  
new tagLunarCal( 31,  05491010110101010 ),
  
new tagLunarCal( 21,  26540101010110101 ),
  
new tagLunarCal( 40,  00590100101101101 ), /* 113 */
  
new tagLunarCal( 28,  62,  51010010101110 ),
  
new tagLunarCal( 47,  03101010010011101 ),
  
new tagLunarCal( 36,  04151101001001101 ),
  
new tagLunarCal( 25,  55201110100100110 ), /* 117 */
  
new tagLunarCal( 43,  00261101010100101 ),
  
new tagLunarCal( 32,  01311101101010100 ),
  
new tagLunarCal( 22,  32360110101101010 ) ];
 
/* 民国年每月之日数 */
 SolarCal 
= [ 312831303130313130313031 ];
 
/* 民国年每月之累积日数, 平年与闰年 */ 
SolarDays 
= [  0315990120151181212243273304334365396,  0316091121152182213244274305335366397 ];
 AnimalIdx 
= ["""""""""""""""""""""""" ];
 LocationIdx 
= [ """""""西" ];
 
if ( SolarYear <= FIRSTYEAR || SolarYear > LASTYEAR ) return 1;
 sm 
= SolarMonth - 1;
  
if ( sm < 0 || sm > 11 ) return 2;
  leap 
= GetLeap( SolarYear );
 
if ( sm == 1 )
  d 
= leap + 28;
 
else
  d 
= SolarCal[sm];
 
if ( SolarDate < 1 || SolarDate > d ) return 3;
 y 
= SolarYear - FIRSTYEAR;
 acc 
= SolarDays[ leap*14 + sm ] + SolarDate;
 kc 
= acc + LunarCal[y].BaseKanChih;
 Kan 
= kc % 10;
 Chih 
= kc % 12;
 Location 
= LocationIdx[kc % 4];
 Age 
= kc % 60;
 
if ( Age < 22 )
  Age 
= 22 - Age;
 
else
  Age 
= 82 - Age;
 Animal 
= AnimalIdx[ Chih ];
 
if ( acc <= LunarCal[y].BaseDays ) {
  y
--;
  LunarYear 
= SolarYear - 1;
  leap 
= GetLeap( LunarYear );
  sm 
+= 12;
  acc 
= SolarDays[leap*14 + sm] + SolarDate;
  }
 
else
  LunarYear 
= SolarYear;
   l1 
= LunarCal[y].BaseDays;
 
for ( i=0; i<13; i++ ) {
  l2 
= l1 + LunarCal[y].MonthDays[i] + 29;
  
if ( acc <= l2 ) break;
  l1 
= l2;
  }
 LunarMonth 
= i + 1;
 LunarDate 
= acc - l1;
 im 
= LunarCal[y].Intercalation;
 
if ( im != 0 && LunarMonth > im ) {
  LunarMonth
--;
  
if ( LunarMonth == im ) LunarMonth = -im;
  }
 
if ( LunarMonth > 12 ) LunarMonth -= 12;
 today
=new Date();
        
function initArray(){
                         
this.length=initArray.arguments.length
                         
for(var i=0;i<this.length;i++)
                         
this[i+1]=initArray.arguments[i]  }
       
var d=new initArray("星期日","星期一","星期二","星期三","星期四","星期五","星期六");
             document.write(
"<span class="jsdhtml"> ", today.getYear()," 年 ",today.getMonth()+1," 月 ",today.getDate()," 日 ",d[today.getDay()+1],"");
   document.write( 
"<span class="jsdhtml">【<u> 农历 " + LunarMonth + "" + LunarDate + "日</u>】" );
                                        
return 0
}
 
/* 求此民国年是否为闰年, 返回 0 为平年, 1 为闰年 */
function GetLeap( year )
 
{
   
if ( year % 400 == 0 )
     
return 1;
   
else if ( year % 100 == 0 )
     
return 0;
   
else if ( year % 4 == 0 )
     
return 1;
   
else
     
return 0;
 }
function tagLunarCal( d, i, w, k, m1, m2, m3, m4, m5, m6, m7, m8, m9, m10, m11, m12, m13) {
 
this.BaseDays = d;         /* 到民国 1 月 1 日到农历正月初一的累积日数 */
 
this.Intercalation = i;    /* 闰月月份. 0==此年没有闰月 */
 
this.BaseWeekday = w;      /* 此年民国 1 月 1 日为星期几再减 1 */
 
this.BaseKanChih = k;      /* 此年民国 1 月 1 日之干支序号减 1 */
 
this.MonthDays = [ m1, m2, m3, m4, m5, m6, m7, m8, m9, m10, m11, m12, m13 ]; /* 此农历年每月之大小, 0==小月(29日), 1==大月(30日) */
}
//-->
CalConv();
</
script
>
11.年历
<
html
>
<
head
>
<
meta 
http-equiv
="Content-Type"
 content
="text/html; charset=gb2312"
>
<
title
>
万年历
</
title
>
<
style
>
th
{
color:#FFF;background-color:#F89807}
td
{
color:#000;background-color:#FDEDCC}
input,textarea,th,td
{
font-size:9pt}
</
style
>
</
head
>
<
body
>
<
div 
id
="hyout"
></
div
>
<
script
>
var hy=new Date()
var hyd=new Date()
var cnt=new Array("","","","","","","")
function hyout(hyy,hym){
    
var outxt=""
    outxt
+="<table border=0 width=100% cellspacing=0><tr><th><font color=#FFFFFF>"
    outxt
+=hym+"月</font>"
    outxt
+="<table border=0 width=100% cellspacing=1 cellpadding=0><tr align=center>"
    
for(i=0;i<cnt.length;i++){
        outxt
+="<td>"+cnt[i]+"</td>"
    }
    outxt
+="</tr><tr align=center>"
    
var j=0
    hyd.setYear(hyy)
    hyd.setMonth(
--hym)
    hyd.setDate(
1)
    
for(var i=1;i<=42;i++){
        
if((i%7)==1&&i>1)outxt+="</tr><tr align=center>"
        
if((i<=hyd.getDay())||(hyd.getMonth()!=hym)){
            outxt
+="<td> </td>"
        }
else{
            hyd.setDate(
++j)
            
if(hyd.getMonth()==hym){
                
if(hyd.getDate()==hy.getDate()&&hyd.getMonth()==hy.getMonth()&&hyd.getYear()==hy.getYear()){
                    outxt
+="<th>"+j+"</th>"
                }
else{
                    outxt
+="<td>"+j+"</td>"
                }
            }
else{
                outxt
+="<td> </td>"
            }
        }
    }
    outxt
+="</tr></table></th></tr><tr><th></th></tr></table>"
    
return outxt
}
function hyouty(hyy){
    hyy
=parseFloat(0+hyy)
    
if(hyy==0) hyy=hy.getYear()
    outxt
="<table width=100% border=1 bordercolor=#000000><form><tr><td colspan=4 align=right>公元:<input type=text name=hyyear size=4 maxlength=4 value="+hyy+"> 年 <input type=button value=查看 οnclick=hyouty(this.form.hyyear.value)></td></form></tr><tr>"
    
for(var i=1;i<=12;i++){
        
if(i%4==1&&i>1)outxt+="</tr><tr>"
        outxt
+="<td>"+hyout(hyy,i)+"</td>"
    }
    outxt
+="</tr></table>"
    document.all[
"hyout"].innerHTML=outxt
}
hyouty(hy.getYear())
</
script
>
</
body
>
</
html
>
 
12.广泛应用的一个日历控件
点评:
本控件界面美观,本人在
多个企业的系统看到该控件,所以分享给大家。
<%
@ Page Language="C#" AutoEventWireup="true" CodeFile="Default2.aspx.cs" Inherits="Default2" 
%>
<
html
>
<
head 
runat
="server"
>
    
<
title
>
日历控件
</
title
>
    
<
script 
type
="text/javascript"
 src
="popcalendar.js"
></
script
>
</
head
>
<
body
>
    
<
form 
id
="form1"
 runat
="server"
>
    
<
div
>
    
<
asp:textbox 
id
="txt_StartCPXG_DATE"
 runat
="server"
 Width
="100px"
 ReadOnly
="True"
 CssClass
="edLine"
></
asp:textbox
>
        
<
img 
id
="Image_blqx1"
 style
="CURSOR: hand"
 onclick
="popUpCalendar(this,document.forms[0].txt_StartCPXG_DATE,'yyyy-mm-dd')"
                                 src
="images/calendar.gif"
 
/></
div
>
    
</
form
>
</
body
>
</
html
>

 

转载地址:https://linuxstyle.blog.csdn.net/article/details/1607712 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:asp.net2.0学习历程 菜鸟到中级程序员的飞跃【月儿原创】
下一篇:C#利用钩子控制鼠标【月儿原创】

发表评论

最新留言

感谢大佬
[***.8.128.20]2024年05月05日 00时57分33秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章