DatePicker(日期选择自定义服务器控件)的实现
来源:互联网 发布:怎么破解公司网络限速 编辑:程序博客网 时间:2024/04/27 17:51
在DotNet中有用户自定义控件(.ascx)和服务器控件(程序代码)
WebControl 类提供所有 Web 服务器控件的公共属性、方法和事件。通过设置在此类中定义的属性,可以控制 Web 服务器控件的外观和行为。
例如在Community中DatePicker控件的实现
public class DatePicker : WebControl, INamingContainer {
DropDownList dropMonth;
DropDownList dropDay;
DropDownList dropYear;
public int Month {
get {
if (ViewState["Month"] == null)
return DateTime.Now.Month;
else
return (int)ViewState["Month"];
}
set { ViewState["Month"] = value; }
}
public int Day {
get {
if (ViewState["Day"] == null)
return DateTime.Now.Day;
else
return (int)ViewState["Day"];
}
set { ViewState["Day"] = value; }
}
public int Year {
get {
if (ViewState["Year"] == null)
return DateTime.Now.Year;
else
return (int)ViewState["Year"];
}
set {
ViewState["Year"] = value;
}
}
public DateTime Date {
get {
//确定服务器控件是否包含子控件。如果不包含,则创建子控件。
EnsureChildControls();
int _year = Int32.Parse(dropYear.SelectedItem.Value);
int _month = Int32.Parse(dropMonth.SelectedItem.Value);
int _day = Int32.Parse(dropDay.SelectedItem.Value);
if (_day > DateTime.DaysInMonth(_year, _month) )
throw new ArgumentException("Invalid date!");
return new DateTime
(
_year,
_month,
_day
);
}
set {
Month = value.Month;
Day = value.Day;
Year = value.Year;
}
}
/// <summary>
/// 通知使用基于合成的实现的服务器控件创建它们包含的任何子控件,以便为回发或呈现做准备。
/// 当开发复合服务器控件或模板服务器控件时,必须重写此方法。
/// </summary>
protected override void CreateChildControls() {
dropMonth = new DropDownList();
Controls.Add(dropMonth);
dropDay = new DropDownList();
Controls.Add(dropDay);
dropYear = new DropDownList();
Controls.Add(dropYear);
if (!Page.IsPostBack) {
// Get a DateTimeFormatInfo object
DateTimeFormatInfo objDateInfo = DateTimeFormatInfo.CurrentInfo;
// Display Months
for (int i=1;i<objDateInfo.MonthNames.Length;i++)
dropMonth.Items.Add(new ListItem(objDateInfo.GetMonthName(i), i.ToString()));
// Display Days
for (int i=1;i<32;i++)
dropDay.Items.Add(i.ToString());
// Display Years
for (int i=DateTime.Now.Year - 5;i<DateTime.Now.Year+5;i++)
dropYear.Items.Add(i.ToString());
dropMonth.Items.FindByValue(Month.ToString()).Selected = true;
dropDay.Items.FindByValue(Day.ToString()).Selected = true;
dropYear.Items.FindByValue(Year.ToString()).Selected = true;
}
}
/// <summary>
/// 将服务器控件内容发送到提供的 HtmlTextWriter 对象,此对象编写将在客户端呈现的内容。
/// 在开发自定义服务器控件时,可以重写此方法以生成 ASP.NET 页的内容。
/// </summary>
/// <param name="tw">HtmlTextWriter 对象</param>
protected override void Render(HtmlTextWriter tw) {
// Get Date Parts
string[] dateParts;
try {
DateTimeFormatInfo objDateInfo = DateTimeFormatInfo.CurrentInfo;
//modify by yukh ,because in some objDateInfo.ShortDatePattern seperate by "-" eg: yyyy-M-d
if (objDateInfo.ShortDatePattern.IndexOf("/")>0)
dateParts = objDateInfo.ShortDatePattern.Split('/');
else
dateParts = objDateInfo.ShortDatePattern.Split('-');
}
catch {
dateParts = new string[]{"m","d","y"};
}
tw.RenderBeginTag(HtmlTextWriterTag.Table);
tw.RenderBeginTag(HtmlTextWriterTag.Tr);
tw.RenderBeginTag(HtmlTextWriterTag.Td);
RenderDatePart(dateParts[0],tw);
tw.RenderEndTag();
tw.RenderBeginTag(HtmlTextWriterTag.Td);
RenderDatePart(dateParts[1],tw);
tw.RenderEndTag();
tw.RenderBeginTag(HtmlTextWriterTag.Td);
RenderDatePart(dateParts[2],tw);
tw.RenderEndTag();
tw.RenderEndTag(); // close row
tw.RenderEndTag(); // close table
}
private void RenderDatePart(string datePart,HtmlTextWriter tw) {
datePart = datePart.ToLower();
if (datePart.StartsWith("m"))
dropMonth.RenderControl(tw); //将服务器控件子级的内容输出到提供的 HtmlTextWriter 对象,
//此对象编写将在客户端呈现的内容。
else
if (datePart.StartsWith("d"))
dropDay.RenderControl(tw);
else
dropYear.RenderControl(tw);
}
}
- DatePicker(日期选择自定义服务器控件)的实现
- 自定义日期选择控件实现单个DatePicker选择起始和结束日期
- 日期选择控件 (DatePicker)
- 日期选择控件-DatePicker
- DatePicker 日期选择对话框的实现
- android 日期选择控件 DatePicker
- 发现一个不错的 日期选择控件 My97 DatePicker
- DatePicker - 基于jQuery 1.7的日期选择控件
- UWP 使用日期选择控件DatePicker时的注意事项
- JAVA Swing日期选择控件datepicker的使用
- JQuery学习笔记:Datepicker日期选择控件
- android DatePicker日期区间选择控件
- android日期选择控件DatePicker小结
- extjs实现年月格式的日期选择(DatePicker)
- react-native DatePicker日期选择组件的实现
- 十、jquery-ui datepicker实现选择一周的日期
- jQuery插件Datepicker日期选择器实现Javascript自定义日期时间选择功能javascript
- 自定义datePicker的实现
- 基于Java Web的文件上传进度显示的一种解决方案
- 中日韩三国并非推Linux产品 而是开发基础层
- 只有一个地球
- zt: SQL*PLUS常用命令和Decode()函数使用技巧
- 中日韩将在6个月内首次合作推出Linux产品
- DatePicker(日期选择自定义服务器控件)的实现
- Taglib入门文章
- JSP避免Form重复提交的三种方案
- Community程序总体流程及MVC模式
- Think Globally and Act Locally
- UML1.5中英日术语对照表(权威!)
- 搞笑集锦
- Community中的程序配置
- 用ASP.NET上传图片并生成带版权信息的缩略图