My97DatePicker是一款非常灵活好用的日期控件。使用非常简单。 

1、下载My97DatePicker组件包 

2、在页面中引入该组件js文件: 
     

3、页面使用两个方式: 
    常规调用:   
    图标触发: 
      
      
     注:$dp.$ 相当于 document.getElementById 

 

http://www.mysuc.com/test/My97DatePicker/也有更详细的解释。

 

1. 简介

目前的版本是:4.0 正式版 发布于2008-05-30

2. 注意事项

  • My97DatePicker目录是一个整体,不可破坏里面的目录结构,也不可对里面的文件改名,可以改目录名
  • My97DatePicker.htm是必须文件,不可删除
  • 各目录及文件的用途: 
    WdatePicker.js 配置文件,在调用的地方仅需使用该文件 
    config.js 语言和皮肤配置文件 
    calendar.js 日期库主文件) 
    My97DatePicker.htm 临时页面文件,不可删除
    目录lang 存放语言文件 
    目录skin 存放皮肤的相关文件
  • 当WdatePicker.js里的属性:$wdate=true时,在input里加上class="Wdate"就会在选择框右边出现日期图标,如果您不喜欢这个样式,可以把class="Wdate"去掉,另外也可以通过修改skin目录下的WdatePicker.css文件来修改样式

3. 支持的浏览器

IE 6.0+ , Firefox 2.0+ , Opera 9.5+ , Safari 3.0+

二. 功能及示例

1. 常规功能

  1. 支持多种调用模式

    除了支持常规在input单击或获得焦点调用外,还支持使用其他的元素如:

    等触发WdatePicker函数来调用弹出日期框

    示例1-1-1 常规调用

     
    onClick="WdatePicker()"/>

    示例1-1-2 图标触发

      
    d12" type="text"/>
    el:$dp.$('d12')})" src="skin/datePicker.gif" width="16" height="22" align="absmiddle">
    注:$dp.$ 相当于 document.getElementById 
    $dp.$ 的详细用法可以参考内置函数

  2. 下拉,输入,导航选择日期

    年月时分秒输入框都具备以下三种特性 
    1. 通过导航图标选择


    2. 直接使用键盘输入数字


    3. 直接从弹出的下拉框中选择


    另:年份输入框有智能提示功能,当用户连续点击同一个导航按钮5次时,会自动弹出年份下拉框

  3. 支持周显示

    可以通过配置isShowWeek属性决定是否限制周,并且在返回日期的时候还可以通过自带的自定义事件和API函数返回选择的周


    示例1-2-1 周显示简单应用

     
    isShowWeek:true})"/>

    示例1-2-2 利用onpicked事件把周赋值给另外的文本框

        您选择了第  (W格式)周, 另外您可以使用WW格式:  周 
    isShowWeek:true,onpicked:function() {$dp.$('d122_1').value=$dp.cal.getP('W','W');$dp.$('d122_2').value=$dp.cal.getP('W','WW');}})"/>

    onpicked 用法详见自定义事件
    $dp.cal.getP 用法详见内置函数
     

  4. 只读开关,高亮周末功能

    设置readOnly属性 true 或 false 可指定日期框是否只读 
    设置highLineWeekDay属性 ture 或 false 可指定是否高亮周末

  5. 操作按钮自定义

    清空按钮和今天按钮,可以根据需要进行自定义,它们分别对应 isShowClear 和 isShowToday 默认值都是true

    示例1-5 禁用清空功能

    最好把readOnly置为true,否则即使隐藏了清空按钮,用户依然可以在输入框里把值delete掉
     
    isShowClear:false,readOnly:true})"/>

  6. 自动选择显示位置

    当控件处在页面边界时,它会自动选择显示的位置,所以没有必要担心弹出框会被页面边界遮住的问题了.

  7. 自定义弹出位置

    当控件处在页面边界时,它会自动选择显示的位置.此外你还可以使用position参数对弹出位置做调整.


    示例1-6 通过position属性,自定义弹出位置

    使用positon属性指定,弹出日期的坐标为{left:100,top:50}
     
    position:{left:100,top:50}})"/>

    position属性的详细用法详见属性表

2. 特色功能

  1. 平面显示

    日期控件支持平面显示功能,只要设置一下eCont属性就可以把它当作日历来使用了,无需触发条件,直接显示在页面上


    示例2-1 平面显示演示

    div1">



    $dp.cal.getDateStr 用法详见内置函数

  2. 支持多种容器

    除了可以将值返回给input以外,还可以通过配置el属性将值返回给其他的元素(如:textarea,div,span)等,带有innerHTML属性的HTML元素

    示例2-2 将日期返回到

    2008-01-01 

    代码:
    demospan">2008-01-01 
    el:'demospan'})" src="My97DatePicker/skin/datePicker.gif" width="16" height="22" align="absmiddle" style="cursor:pointer" />

  3. 起始日期功能 
    注意:日期格式必须与 realDateFmt 和 realTimeFmt 一致

    有时在项目中需要选择生日之类的日期,而默认点开始日期都是当前日期,导致年份选择非常麻烦,你可以通过起始日期功能加上配置alwaysUseStartDate属性轻松解决此类问题

    示例2-3-1 起始日期简单应用

    默认的起始日期为 1980-05-01
    当日期框为空值时,将使用 1980-05-01 做为起始日期 

     
    startDate:'1980-05-01'})"/>

    示例2-3-2 alwaysUseStartDate属性应用

    默认的起始日期为 1980-05-01
    当日期框无论是何值,始终使用 1980-05-01 做为起始日期 

     
    startDate:'1980-05-01',alwaysUseStartDate:true})"/>

    示例2-3-3 使用内置参数

    除了使用静态的日期值以外,还可以使用动态参数(如:%y,%M分别表示当前年和月)

    下例演示,年月日使用当年当月的1日,时分秒使用00:00:00作为起始时间

     
    startDate:'%y-%M-01 00:00:00',dateFmt:'yyyy-MM-dd HH:mm:ss',alwaysUseStartDate:true})"/>

  4. 自定义格式

    yMdHmswW分别代表年月日时分秒星期周,你可以任意组合这些元素来自定义你个性化的日期格式.


    日期格式表
    y 将年份表示为最多两位数字。如果年份多于两位数,则结果中仅显示两位低位数。
    yy 同上,如果小于两位数,前面补零。
    yyy 将年份表示为三位数字。如果少于三位数,前面补零。
    yyyy 将年份表示为四位数字。如果少于四位数,前面补零。
    M 将月份表示为从 1 至 12 的数字
    MM 同上,如果小于两位数,前面补零。
    d 将月中日期表示为从 1 至 31 的数字。
    dd 同上,如果小于两位数,前面补零。
    H 将小时表示为从 0 至 23 的数字。
    HH 同上,如果小于两位数,前面补零。
    m 将分钟表示为从 0 至 59 的数字。
    mm 同上,如果小于两位数,前面补零。
    s 将秒表示为从 0 至 59 的数字。
    ss 同上,如果小于两位数,前面补零。
    w 返回星期对应的数字 0 (星期天) - 6 (星期六) 。
    D 返回星期的缩写 一 至 六 (英文状态下 Sun to Sat) 。
    W 返回周对应的数字 (1 - 53) 。
    WW 同上,如果小于两位数,前面补零 (01 - 53) 。

    示例
    yyyy-MM-dd HH:mm:ss 2008-03-12 19:20:00
    yy年M月 08年3月
    yyyyMMdd 20080312
    今天是:yyyy年M年d HH时mm分 今天是:2008年3月12日 19时20分
    H:m:s 19:20:0
    y年 8年

    示例 2-4-1: 年月日时分秒

     
    dateFmt:'yyyy年MM月dd日 HH时mm分ss秒'})" class="Wdate" style="width:300px"/>

    示例 2-4-2 时分秒

     
    dateFmt:'H:mm:ss'})" class="Wdate"/>

    注意:这里提前使用了皮肤(skin)属性,所以你会看到一个不同的皮肤,皮肤属性详见自定义和动态切换皮肤

    示例 2-4-3 年月

     
    dateFmt:'yyyy年MM月'})" class="Wdate"/>

    示例 2-4-4 取得系统可识别的日期值(重要)

    类似于 1999年7月5日 这样的日期是不能够被系统识别的,他必须转换为能够识别的类型如 1999-07-05 

     真实的日期值是:  
    {dateFmt:'yyyy年M月d日',vel:'d244_2'})"/>
    d244_2" type="text" />

    注意:在实际应用中,一般会把vel指定为一个hidden控件,这里是为了把真实值展示出来,所以使用文本框
    关键属性: vel 指定一个控件或控件的ID,必须具有value属性(如input),用于存储真实值(也就是realDateFmt和realTimeFmt格式化后的值)

  5. 编辑功能

    不知道您是否已经注意到,当日期框里面有值时,右下角的按钮会变成更新,修改完某个属性后,只要点击这个按钮就可以实现时间和日期的编辑

    示例2-5 日期和时间的编辑演示

    您可以尝试对下面框中的月份改为1,然后点击更新,你会发现日期由 2000-02-29 01:00:00 变为 2000-01-29 01:00:00
     

  6. 自动纠错功能

    纠错处理可设置为3种模式:提示(默认) 自动纠错 标记,当日期框中的值不符合格式时,系统会尝试自动修复,如果修复失败会根据您设置的纠错处理模式进行处理,错误判断功能非常智能它可以保证用户输入的值是一个合法的值

    示例2-6-1 不合法的日期演示

    请在下面的日期框中填入一个不合法的日期(如:1997-02-29),再尝试离开焦点
    使用默认容错模式 提示模式 errDealMode = 0 在输入错误日期时,会先提示 
     

    注意:1997年不是闰年哦

    示例2-6-2 超出日期限制范围的日期也被认为是一个不合法的日期

    最大日期是2000-01-10 ,如果在下框中填入的日期 大于 2000-01-10(如2000-01-12)也会被认为是不合法的日期 
    自动纠错模式 errDealMode = 1 在输入错误日期时,自动恢复前一次正确的值
     

    示例2-6-3 使用无效天和无效日期功能限制的日期也被认为是一个不合法的日期

    如:
    2008-02-20 无效日期限制
    2008-02-02 2008-02-09 2008-02-16 2008-02-23 无效天限制
    都是无效日期
    您可以尝试在下框中输入这些日期,并离开焦点

    标记模式 errDealMode = 2 在输入错误日期时,不做提示和更改,只是做一个标记,但此时日期框不会马上隐藏
     

    注意:标记类:WdateFmtErr是在skin目录下WdatePicker.css中定义的

  7. 跨无限级框架显示

    无论你把日期控件放在哪里,你都不需要担心会被外层的iframe所遮挡进而影响客户体验,因为My97日期控件是可以跨无限级框架显示的

    示例2-7 跨无限级框架演示

    可无限跨越框架iframe,无论怎么嵌套框架都不必担心了,即使有滚动条也不怕

  8. 民国年日历和其他特殊日历

    当年份格式设置为yyy格式时,利用年份差量属性yearOffset(默认值1911民国元年),可实现民国年日历和其他特殊日历

    示例2-8 民国年演示

     
    dateFmt:'yyy/MM/dd'})"/>

    注意:年份格式设置成yyy时,真正的日期将会减去一个差量yearOffset(默认值为:1911),如果是民国年使用默认值即可无需另外配置,如果是其他的差量,可以通过参数的形式配置

  9. 为编程带来方便

    如果el的值是this,可省略,即所有的el:this都可以不写 
    日期框设置为disabled时,禁止更改日期(不弹出选择框) 
    如果没有定义onpicked事件,自动触发文本框的onchange事件 
    如果没有定义oncleared事件,清空时,自动触发onchange事件

  10. 其他属性

    设置readOnly属性,可指定日期框是否只读 
    设置highLineWeekDay属性,可指定是否高亮周末 
    设置isShowOthers属性,可指定是否显示其他月的日期 
    加上class="Wdate"就会在选择框右边出现日期图标