⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 calendar.cs

📁 c# vs2005(asp.net2.0) 下的一个日期控件,来自网上的脚本,对其作了更改,修改了些错误,目前已经在项目中使用,感觉不错
💻 CS
📖 第 1 页 / 共 2 页
字号:
using System;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.ComponentModel;
using System.Web.UI.Design;
using System.Drawing.Design;
using System.Drawing;
using System.Globalization;


namespace WFNetCtrl
{
	//============高处不胜寒.Net日期控件 1.1版=================
	//    
	//                   '''
	//                  (0 0)
	//      +-----oOO----(_)------------+
	//      |                           |
	//      |   作者:高处不胜寒         |
	//      |   QQ:28767360             |
	//      |   AspXCn QQ群:           | 
	//      |   类型:Wap版             |
	//      |   更新时间:2005-07-23   |
	//      |                           |
	//      +------------------oOO------+
	//                 |__|__|
	//                  || ||
	//                 ooO Ooo  
	//
	//===========================================
	/// <summary>
	/// Calendar 的摘要说明。
	/// </summary>
	public class Calendar : System.Web.UI.WebControls.TextBox
	{
		bool write;

		public Calendar()
		{
			//
			// TODO: 在此处添加构造函数逻辑
			//
		}
		[Description("是否可以写入日期")]
		public bool IsWrite
		{
			get
			{
				return write;
			}

			set
			{
				write= value;
			}
		}
		private const string str_Js=@"
        <script language=""javascript"">
        //----------------------------------------------------------------------------
		//----------------------------------------------------------------------------
        //  高处不胜寒.Net日期控件 1.1版
		//  主调用函数是 setday(this,[object])和setday(this),[object]是控件输出的控件名,举两个例子:
		//  一、<input name=txt><input type=button value=setday onclick=""setday(this,document.all.txt)"">
		//  二、<input onfocus=""setday(this)"">
		//  若有什么不足的地方,或者您有更好的建议,请与我联系:mail: meizz@hzcnc.com
		//  本日历的年份限制是(1000 - 9999)
		//  按ESC键关闭该控件
		//  在年和月的显示地方点击时会分别出年与月的下拉框
		//  控件外任意点击一点即可关闭该控件
		/* 以下为walkingpoison的修改说明
		walkingpoison联系方式:wayx@kali.com.cn

		Ver	2.0
		修改日期:2002-12-13
		修改内容:
		1.*全新修改使用iframe作为日历的载体,不再被select和flash等控件挡住。
		2.修正了移植到iframe后移动日历控件的问题。

		Ver	1.5
		修改日期:2002-12-4
		修改内容:
		1.选中的日期显示为凹下去的样式
		2.修改了关闭层的方法,使得失去焦点的时候能够关闭日历。
		3.修改按键处理,使得Tab切换焦点的时候可以关闭控件
		4.*可以自定义日历是否可以拖动

		Ver 1.4
		修改日期:2002-12-3
		修改内容:
		1.修正选中年/月份下拉框后按Esc键导致年/月份不显示的问题
		2.修正使用下拉框选择月份造成的日期错误(字符串转化为数字的问题)
		3.*外观样式的改进,使得控件从丑小鸭变成了美丽的天鹅,从灰姑娘变成了高贵的公主,从……(读者可以自己进行恰当的比喻)
		4.再次增大年/月份的点击空间,并对下拉框的位置稍作调整

		注:*号表示比较关键的改动

		说明:
		1.受到iframe的限制,如果拖动出日历窗口,则日历会停止移动。
		*/

		//==================================================== 参数设定部分 =======================================================
		var bMoveable=true;		//设置日历是否可以拖动
		var _VersionInfo=""Version:2.0&#13;2.0作者:walkingpoison&#13;1.0作者: F.R.Huang(meizz)&#13;MAIL: meizz@hzcnc.com""	//版本信息

		//==================================================== WEB 页面显示部分 =====================================================
		var strFrame;		//存放日历层的HTML代码
		document.writeln('<iframe bgcolor=""#000000"" id=meizzDateLayer Author=wayx frameborder=0 style=""position: absolute;  width: 186; height: 247; z-index: 9998; display: none""></iframe>');
		strFrame='<style>';
		strFrame+='INPUT.button{BORDER-RIGHT: #B3C9E1 1px solid;BORDER-TOP: #B3C9E1 1px solid;BORDER-LEFT: #B3C9E1 1px solid;';
		strFrame+='BORDER-BOTTOM: #ff9900 1px solid;BACKGROUND-COLOR: #EDF2F8;font-family:宋体;}';
		strFrame+='TD{FONT-SIZE: 9pt;font-family:宋体;}';
		strFrame+='</style>';
		strFrame+='<scr' + 'ipt>';
		strFrame+='var datelayerx,datelayery;	/*存放日历控件的鼠标位置*/';
		strFrame+='var bDrag;	/*标记是否开始拖动*/';
		strFrame+='function document.onmousemove()	/*在鼠标移动事件中,如果开始拖动日历,则移动日历*/';
		strFrame+='{if(bDrag && window.event.button==1)';
		strFrame+='	{var DateLayer=parent.document.all.meizzDateLayer.style;';
		strFrame+='		DateLayer.posLeft += window.event.clientX-datelayerx;/*由于每次移动以后鼠标位置都恢复为初始的位置,因此写法与div中不同*/';
		strFrame+='		DateLayer.posTop += window.event.clientY-datelayery;}}';
		strFrame+='function DragStart()		/*开始日历拖动*/';
		strFrame+='{var DateLayer=parent.document.all.meizzDateLayer.style;';
		strFrame+='	datelayerx=window.event.clientX;';
		strFrame+='	datelayery=window.event.clientY;';
		strFrame+='	bDrag=true;}';
		strFrame+='function DragEnd(){		/*结束日历拖动*/';
		strFrame+='	bDrag=false;}';
		strFrame+='</scr' + 'ipt>';
		strFrame+='<div style=""z-index:9999;position: absolute; left:0; top:0;"" onselectstart=""return false""><span id=tmpSelectYearLayer Author=wayx style=""z-index: 9999;position: absolute;top: 3; left: 19;display: none""></span>';
		strFrame+='<span id=tmpSelectMonthLayer Author=wayx style=""z-index: 9999;position: absolute;top: 3; left: 78;display: none""></span>';
		strFrame+='<table style=""FILTER:dropshadow(color=#EDEDF8,offx=3.3,offy=3.3,positive=1);"" cellSpacing=""0"" cellPadding=""0"" width=""100%"" border=""0""><tr><td>';
        // 控件边框颜色
        strFrame+='<table border=1 cellspacing=0 cellpadding=0 width=182 height=160 bgColor=""#FFFFFF"" borderColorLight=#7197CA borderColorDark=""#ffffff""  Author=""wayx"">';
		strFrame+='  <tr Author=""wayx""><td width=182 height=23 Author=""wayx"" bgcolor=#FFFFFF><table border=0 cellspacing=1 cellpadding=0 width=180 Author=""wayx"" height=23>';
		strFrame+='      <tr align=center Author=""wayx""><td width=16 align=center bgcolor=#B6CAE4 style=""font-size:12px;cursor: hand;color: #ffffff"" ';
		strFrame+='        onclick=""parent.meizzPrevM()"" title=""向前翻 1 月"" Author=meizz><b Author=meizz>&lt;</b>';
		strFrame+='        </td><td width=60 align=center style=""font-size:12px;cursor:default"" Author=meizz ';
		strFrame+='onmouseover=""style.backgroundColor=\'#D7E1F0\'"" onmouseout=""style.backgroundColor=\'white\'"" ';
		strFrame+='onclick=""parent.tmpSelectYearInnerHTML(this.innerText.substring(0,4))"" title=""点击这里选择年份""><span Author=meizz id=meizzYearHead></span></td>';
		strFrame+='<td width=48 align=center style=""font-size:12px;cursor:default"" Author=meizz onmouseover=""style.backgroundColor=\'#D7E1F0\'"" ';
		strFrame+=' onmouseout=""style.backgroundColor=\'white\'"" onclick=""parent.tmpSelectMonthInnerHTML(this.innerText.length==3?this.innerText.substring(0,1):this.innerText.substring(0,2))""';
		strFrame+='        title=""点击这里选择月份""><span id=meizzMonthHead Author=meizz></span></td>';
		strFrame+='        <td width=16 bgcolor=#B6CAE4 align=center style=""font-size:12px;cursor: hand;color: #ffffff"" ';
		strFrame+='         onclick=""parent.meizzNextM()"" title=""向后翻 1 月"" Author=meizz><b Author=meizz>&gt;</b></td></tr>';
		strFrame+='    </table></td></tr>';
		strFrame+='  <tr Author=""wayx""><td width=180 height=18 Author=""wayx"">';
		strFrame+='<table border=1 cellspacing=0 cellpadding=0 bgcolor=#618BC5 ' + (bMoveable? 'onmousedown=""DragStart()"" onmouseup=""DragEnd()""':'');
		strFrame+=' BORDERCOLORLIGHT=#3677b1 bgcolor=#5168C8 BORDERCOLORDARK=#FFFFFF width=""100%"" height=25 Author=""wayx"" style=""cursor:' + (bMoveable ? 'move':'default') + '"">';
		strFrame+='<tr Author=""wayx"" valign=""middle"" align=""center""><td style=""font-size:12px;color:#FFFFFF"" Author=meizz><b>日</b></td>';
		strFrame+='<td style=""font-size:12px;color:#FFFFFF""  Author=meizz><b>一</b></td><td style=""font-size:12px;color:#FFFFFF"" Author=meizz><b>二</b></td>';
		strFrame+='<td style=""font-size:12px;color:#FFFFFF"" Author=meizz><b>三</b></td><td style=""font-size:12px;color:#FFFFFF"" Author=meizz><b>四</b></td>';
		strFrame+='<td style=""font-size:12px;color:#FFFFFF""   Author=meizz><b>五</b></td><td style=""font-size:12px;color:#FFFFFF"" Author=meizz><b>六</b></td></tr>';
		strFrame+='</table></td></tr><!-- Author:F.R.Huang(meizz) http://www.meizz.com/ mail: meizz@hzcnc.com 2002-10-8 -->';
		strFrame+='  <tr Author=""wayx""><td width=""100%"" height=120 Author=""wayx"">';
		strFrame+='    <table border=1 cellspacing=2 cellpadding=0 borderColorDark=#ffffff bgColor=#FFFFFF borderColorLight=#83A4D1 width=""100%"" height=120 Author=""wayx"">';
		var n=0; for (j=0;j<5;j++){ strFrame+= ' <tr align=center Author=""wayx"">'; for (i=0;i<7;i++){
		strFrame+='<td width=25 height=25 id=meizzDay'+n+' style=""font-size:12px"" Author=meizz onclick=parent.meizzDayClick(this.innerText,0)></td>';n++;}
		strFrame+='</tr>';}
		strFrame+='      <tr align=center Author=""wayx"">';
		for (i=35;i<39;i++)strFrame+='<td width=25 height=25 id=meizzDay'+i+' style=""font-size:12px"" Author=wayx onclick=""parent.meizzDayClick(this.innerText,0)""></td>';
		strFrame+='        <td colspan=3 align=right Author=meizz><span onclick=parent.closeLayer() style=""font-size:12px;cursor: hand""';
		strFrame+='         Author=meizz title=""' + _VersionInfo + '""><u>关闭</u></span>&nbsp;</td></tr>';
		strFrame+='    </table></td></tr><tr Author=""wayx""><td Author=""wayx"">';
		strFrame+='        <table border=0 cellspacing=1 cellpadding=0 width=100% Author=""wayx"" bgcolor=#FFFFFF>';
		strFrame+='          <tr Author=""wayx""><td Author=meizz align=left><input Author=meizz type=button class=button style=""cursor:hand"" value=""<<"" title=""向前翻 1 年"" onclick=""parent.meizzPrevY()"" ';
		strFrame+='             onfocus=""this.blur()"" style=""font-size: 12px; height: 20px""><input Author=meizz class=button title=""向前翻 1 月"" type=button ';
		strFrame+='             value=""< "" style=""cursor:hand"" onclick=""parent.meizzPrevM()"" onfocus=""this.blur()"" style=""font-size: 12px; height: 20px""></td><td ';
		strFrame+='             Author=meizz align=center><input Author=meizz style=""cursor:hand""  type=button class=button value=Today onclick=""parent.meizzToday()"" ';
		strFrame+='             onfocus=""this.blur()"" title=""当前日期"" style=""font-size: 12px; height: 20px; cursor:hand""></td><td ';
		strFrame+='             Author=meizz align=right><input Author=meizz type=button class=button value="" >"" style=""cursor:hand"" onclick=""parent.meizzNextM()"" ';
		strFrame+='             onfocus=""this.blur()"" title=""向后翻 1 月"" class=button style=""font-size: 12px; height: 20px""><input ';
		strFrame+='             Author=meizz type=button class=button style=""cursor:hand"" value="">>"" title=""向后翻 1 年"" onclick=""parent.meizzNextY()""';
		strFrame+='             onfocus=""this.blur()"" style=""font-size: 12px; height: 20px""></td>';
		strFrame+='</tr></table></td></tr></table></td></tr></table></div>';

		window.frames.meizzDateLayer.document.writeln(strFrame);
		window.frames.meizzDateLayer.document.close();		//解决ie进度条不结束的问题

		//==================================================== WEB 页面显示部分 ======================================================
		var outObject;
		var outButton;		//点击的按钮
		var outDate="""";		//存放对象的日期
		var odatelayer=window.frames.meizzDateLayer.document.all;		//存放日历对象
		function setday(tt,obj) //主调函数
		{
			if (arguments.length >  2){alert(""对不起!传入本控件的参数太多!"");return;}
			if (arguments.length == 0){alert(""对不起!您没有传回本控件任何参数!"");return;}
			var dads  = document.all.meizzDateLayer.style;
			var th = tt;
			var ttop  = tt.offsetTop;     //TT控件的定位点高
			var thei  = tt.clientHeight;  //TT控件本身的高
			var tleft = tt.offsetLeft;    //TT控件的定位点宽
			var ttyp  = tt.type;          //TT控件的类型
			while (tt = tt.offsetParent){ttop+=tt.offsetTop; tleft+=tt.offsetLeft;}
			dads.top  = (ttyp==""image"")? ttop+thei : ttop+thei+6;
			dads.left = tleft;
			outObject = (arguments.length == 1) ? th : obj;
			outButton = (arguments.length == 1) ? null : th;	//设定外部点击的按钮
			//根据当前输入框的日期显示日历的年月
			var reg = /^(\d+)-(\d{1,2})-(\d{1,2})$/; 
			var r = outObject.value.match(reg); 
			if(r!=null){
				r[2]=r[2]-1; 
				var d= new Date(r[1], r[2],r[3]); 
				if(d.getFullYear()==r[1] && d.getMonth()==r[2] && d.getDate()==r[3]){
					outDate=d;		//保存外部传入的日期
				}
				else outDate="""";
					meizzSetDay(r[1],r[2]+1);
			}
			else{
				outDate="""";
				meizzSetDay(new Date().getFullYear(), new Date().getMonth() + 1);
			}
			dads.display = '';

			event.returnValue=false;
		}

		var MonHead = new Array(12);    		   //定义阳历中每个月的最大天数
			MonHead[0] = 31; MonHead[1] = 28; MonHead[2] = 31; MonHead[3] = 30; MonHead[4]  = 31; MonHead[5]  = 30;
			MonHead[6] = 31; MonHead[7] = 31; MonHead[8] = 30; MonHead[9] = 31; MonHead[10] = 30; MonHead[11] = 31;

		var meizzTheYear=new Date().getFullYear(); //定义年的变量的初始值
		var meizzTheMonth=new Date().getMonth()+1; //定义月的变量的初始值
		var meizzWDay=new Array(39);               //定义写日期的数组

		function document.onclick() //任意点击时关闭该控件	//ie6的情况可以由下面的切换焦点处理代替
		{ 
		with(window.event)
		{ if (srcElement.getAttribute(""Author"")==null && srcElement != outObject && srcElement != outButton)
			closeLayer();
		}
		}

		function document.onkeyup()		//按Esc键关闭,切换焦点关闭
		{
			if (window.event.keyCode==27){
				if(outObject)outObject.blur();
				closeLayer();
			}
			else if(document.activeElement)
				if(document.activeElement.getAttribute(""Author"")==null && document.activeElement != outObject && document.activeElement != outButton)
				{
					closeLayer();
				}
		}

		function meizzWriteHead(yy,mm)  //往 head 中写入当前的年与月
		{
			odatelayer.meizzYearHead.innerText  = yy + "" 年"";
			odatelayer.meizzMonthHead.innerText = mm + "" 月"";

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -