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

📄 calendar.cs

📁 一个简单的Demo
💻 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
{
	/// <summary>
	/// Calendar 的摘要说明。
	/// </summary>
         /*  
                ************************************************
                以下为redstar修改说明 
                原版本功能很强大,有些地方用起来反而不是特别方便,所以我根据自己项目的需要进行了一点简化。
                可能与原作者的本意背道而驰,在此致歉,如有需要,大家可以搜索作者原版代码
                ************************************************
                */
                
                /*
                ×××××××××××××××××××××××××××××××××××××××××××××××××××
                ×××××××××××××××××××××××××××××××××××××××××××××××××××
                ×××××××××××××××××××××××××××××××××××××××××××××××××××
                
                以下为原版本中说明



                //----------------------------------------------------------------------------
		//----------------------------------------------------------------------------
		//  这是梅花雨做的一个日历 Javascript 页面脚本控件,经高处不胜寒修改并封装,适用于微软的 IE (5.0以上)浏览器
		//  主调用函数是 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的限制,如果拖动出日历窗口,则日历会停止移动。
		*/


	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"">
		//==================================================== 参数设定部分 =======================================================
		var bMoveable=false;		//设置日历是否可以拖动

		//==================================================== WEB 页面显示部分 =====================================================
		var strFrame;		//存放日历层的HTML代码
		document.writeln('<iframe bgcolor=""#000000"" id=meizzDateLayer Author=wayx frameborder=0 scrolling=""no"" style=""position: absolute;  width:160px; height:140px; 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=""147"" border=""0""><tr><td>';
        // 控件边框颜色
        strFrame+='<table border=1 cellspacing=0 cellpadding=0 width=147 height=100 bgColor=""#FFFFFF"" borderColorLight=#7197CA borderColorDark=""#ffffff""  Author=""wayx"">';
		strFrame+='  <tr Author=""wayx""><td width=147 height=23 Author=""wayx"" bgcolor=#FFFFFF><table border=0 cellspacing=1 cellpadding=0 width=147 Author=""wayx"" height=23>';
		strFrame+='      <tr align=center Author=""wayx""><td width=10 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=10 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=""147"" height=108 Author=""wayx"">';
		strFrame+='    <table border=1 cellspacing=2 cellpadding=0 borderColorDark=#ffffff bgColor=#FFFFFF borderColorLight=#83A4D1 width=""147"" height=108 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=21 height=18 id=meizzDay'+n+' style=""font-size:12px"" Author=meizz onclick=parent.meizzDayClick(this.innerText,0)></td>';n++;}
		strFrame+='</tr>';}
		
        strFrame+='</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;
            dads.width=160;
			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 + "" 月"";
		}

		function tmpSelectYearInnerHTML(strYear) //年份的下拉框
		{
		if (strYear.match(/\D/)!=null){alert(""年份输入参数不是数字!"");return;}
		var m = (strYear) ? strYear : new Date().getFullYear();
		if (m < 1000 || m > 9999) {alert(""年份值不在 1000 到 9999 之间!"");return;}
		var n = m - 10;
		if (n < 1000) n = 1000;
		if (n + 26 > 9999) n = 9974;
		var s = ""<select Author=meizz name=tmpSelectYear style='font-size: 12px' ""

⌨️ 快捷键说明

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