原创控件代码共享--日期选择控件

思路:实现日期年月日的选择

1、可以设定年的起止年份

2、排除不正确日期选择的可能

3、使用javascript实现控制

4、使用Text属性方便获取设置日期值

=================================

代码如下:

using System;

using System.Collections;

using System.Collections.Specialized;

using System.ComponentModel;

using System.IO;

using System.Text;

using System.Web.UI;

using System.Web.UI.Design.WebControls;

using System.Web.UI.WebControls;

namespace JSY

{

/// <summary>

/// AspNetDate 选择输入日期控件

/// </summary>

[DefaultProperty("Text"),

ParseChildren(false),

PersistChildren(false),

Description("专用于ASP.Net Web应用程序的日期控件"),

Designer(typeof(DateDesigner)),

ToolboxData("<{0}:JSYNetDate runat=server></{0}:JSYNetDate>")]

public class JSYNetDate:Panel,INamingContainer,IPostBackDataHandler

{

#region 属性

/// <summary>

/// 获取/设置日期值。

/// </summary>

[Bindable(true),

Browsable(true),

Description("日期值"),

Category("外观"),

DefaultValue("")]

public string Text

{

get

{

if (ViewState["Text"] != null)

{

return ViewState["Text"].ToString();

}

else

{

if (IsNull)

{

return "";

}

else

{

DateTime date=System.DateTime.Today;

string str="";

switch (DateFormat)

{

case "YMD":

str=date.ToString("yyyy-MM-dd",System.Globalization.DateTimeFormatInfo.InvariantInfo);

break;

case "YM":

str=date.ToString("yyyy-MM",System.Globalization.DateTimeFormatInfo.InvariantInfo);

break;

case "Y":

str=date.Year.ToString();

break;

}

return str;

}

}

}

set

{

if (value=="")

{

ViewState["Text"] = "";

}

else if (DateFormat=="YMD")

{

DateTime date;

try

{

date=Convert.ToDateTime(value);

}

catch

{

date=System.DateTime.Today;

}

string str = date.ToString("yyyy-MM-dd",System.Globalization.DateTimeFormatInfo.InvariantInfo);

if (str=="1900-01-01")

str="";

ViewState["Text"] =str;

}

else

{

ViewState["Text"] = value;

}

}

}

/// <summary>

/// 获取/设置日期值是否允许空。

/// </summary>

[Browsable(true),

Description("日期值是否允许空"),

Category("布局"),

DefaultValue(false)]

public bool IsNull

{

get

{

return (ViewState["IsNull"]==null)?false:true;

}

set

{

if (value)

ViewState["IsNull"]=true;

}

}

/// <summary>

/// 获取/设置日期值格式(YMD:年-月-日 YM:年-月 Y:年)。

/// </summary>

[Browsable(true),

Description("日期值格式(YMD:年-月-日 YM:年-月 Y:年)"),

Category("布局"),

DefaultValue("YMD")]

public string DateFormat

{

get

{

return (ViewState["DateFormat"]==null)?"YMD":(string)ViewState["DateFormat"];

}

set

{

ViewState["DateFormat"]=value;

}

}

/// <summary>

/// 获取/设置日期值能否编辑。

/// </summary>

[Browsable(true),

Description("能否编辑"),

Category("行为"),

DefaultValue(true)]

public override bool Enabled

{

get

{

return (ViewState["Enabled"]==null)?true:false;

}

set

{

if (!value)

ViewState["Enabled"]=false;

}

}

/// <summary>

/// 获取/设置日期值中可供选择的年份长度。

/// </summary>

[Browsable(true),

Description("日期值中可供选择的年份长度"),

Category("布局"),

DefaultValue(100)]

原创控件代码共享--日期选择控件

时间: 2024-12-18 05:20:09

原创控件代码共享--日期选择控件的相关文章

用c/c++混合编程方式为ios/android实现一个自绘日期选择控件(一)

本文为原创,如有转载,请注明出处:http://www.cnblogs.com/jackybu 前言 章节: 1.需求描述以及c/c++实现日期和月历的基本操作 2.ios实现自绘日期选择控件 3.android实现自绘日期选择控件 目的: 通过一个相对复杂的自定义自绘控件来分享: 1.ios以及android自定义自绘控件的开发流程 2.objc与c/c++混合编程 3.android ndk的环境配置,android studio ndk的编译模式,swig在android ndk开发中的作

双日历日期选择控件

近期,需要在项目里使用日历,经过多方选择,最后决定使用 daterangepicker  (http://www.daterangepicker.com),代码下载地址 https://github.com/dangrossman/bootstrap-daterangepicker 但是,该控件是一个日期范围选择控件,使用singleDatePicker 可以变成单日期选择控件,但是只显示一个日期. 看了一下源代码,主要是在 daterangepicker.js 的有一段代码,注释掉即可:如下

Android自定义View(RollWeekView-炫酷的星期日期选择控件)

转载请标明出处: http://blog.csdn.net/xmxkf/article/details/53420889 本文出自:[openXu的博客] 目录: 1分析 2定义控件布局 3定义CustomWeekView 4重写onMeasure 5点击后执行动画 7重置预备控件 源码下载 ??最近收到一个自定义控件的需求,需要做一个日期选择控件,实现图如下: ???? ??一次展示一个星期的5天,中间放大的为当前选中的:如果点击了其中一个日期,比如星期五,那么整体向左滑动,并将星期五慢慢放大

ExtJS6.0扩展日期选择控件为也可以选择时间

PS:ExtJS自带的日期选择控件只能够选择日期,但是现在的需求需要精确到秒,所以在网上搜索了一些例子(大部分是4.0的)作为参考,然后改出了6.0可用的一个日期时间选择控件. 1.找到extjs6.0源代码中Picker文件路径下的Date.js脚本(路径:ext-6.0.0-gpl\ext-6.0.0\classic\classic\src\picker),拷贝一份出来命名为DateTimePicker.js 2.修改命名空间(把白色底的改成黑色底的命名空间以及别名,你也可以修改为自己存放该

Swift - 日期选择控件(UIDatePicker)的用法

1,使用storyboard创建日期选择控件 首先我们将一个UIDatePicker控件和一个按钮直接添加到Main.Storyboard上.该按钮是为了点击时弹出提示框显示当前选择的日期和时间. 同时在ViewController.swift中使用IBOutlet建立起控件和事件的关联,具体代码如下: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 class ViewContro

取消layUI中日期选择控件默认填充日期

input标签中使用日期选择控件填写,加载时默认填充当前日期, 标签设置了placeholder="请选择" autocomplete="off",但是并没有效果, 最后发现可以在绑定时将value一项设置为空,而非new Data()的值, laydate.render({    elem: '#param_monthid',    type: 'month',    format: 'yyyyMM',    value: '',    max: year + &

高仿IOS7日期选择控件

高仿IOS7日期选择控件 高仿IOS7.QQ等日期选择控件,滑动选择,高端大气上档次,可直接运用于项目中... 下载地址:http://www.devstore.cn/code/info/965.html 运行截图:   

Atitit.ui控件---下拉菜单选择控件的实现select html

Atitit.ui控件---下拉菜单选择控件的实现select   html 1. 调用& model的实现 1 2. -----select.jsp------ 1 1. 调用& model的实现 Proj.vod2 <% List li=new ArrayList(); Map m=new HashMap (); m.put("lab","爱情"); m.put("v","1"); li.add(m)

038. asp.netWeb用户控件之六实现日期选择的用户控件

web用户控件的ascx代码: <%@ Control Language="C#" AutoEventWireup="true" CodeFile="SelectDate.ascx.cs" Inherits="SelectDate" %> <script type="text/javascript" src="js/jquery.1.3.2.min.js"><