My97DatePicker使用说明文档
<script type="text/javascript" src="$contextPath$/resources/tho/My97DatePicker/WdatePicker.js" defer="defer"></script>
. 简介
1. 简介
目前的版本是:4.2 正式版 发布于2008-12-03
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单击或获得焦点调用外,还支持使用其他的元素如:<img><div>等触发WdatePicker函数来调用弹出日期框
示例1-1-1 常规调用

<input id="d11" type="text" onClick="WdatePicker()"/>
示例1-1-2 图标触发

<input id="d12" type="text"/>
<img onclick="WdatePicker({el:$dp.$('d12')})" src="../skin/datePicker.gif" width="16" height="22" align="absmiddle">
:$dp.$ 相当于 ElementById
$dp.$ 的详细用法可以参考内置函数
2. iframe参数传递下拉,输入,导航选择日期
年月时分秒输入框都具备以下三种特性
1. 通过导航图标选择


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



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


:年份输入框有智能提示功能,当用户连续点击同一个导航按钮5次时,会自动弹出年份下拉框
3. 支持周显示
可以通过配置isShowWeek属性决定是否限制周,并且在返回日期的时候还可以通过自带的自定义事件和API函数返回选择的周
示例1-2-1 周显示简单应用

<input id="d121" type="text" onfocus="WdatePicker({isShowWeek:true})"/>
示例1-2-2 利用onpicked事件把周赋值给另外的文本框
  您选择了第 (W格式), 另外您可以使用WW格式:
<input type="text" class="Wdate" id="d122" onFocus="WdatePicker({isShowWeek:true,onpicked:function() {$dp.$('d122_1').value=$P('W','W');$dp.$('d122_2').value=$P('W','WW');}})"/>

onpicked 用法详见自定义事件
$P 用法详见内置函数
4. 只读开关,高亮周末功能
设置readOnly属性 true false 可指定日期框是否只读
设置highLineWeekDay属性 ture false 可指定是否高亮周末
5. 操作按钮自定义
清空按钮和今天按钮,可以根据需要进行自定义,它们分别对应 isShowClear isShowToday 默认值都是true
示例1-5 禁用清空功能
最好把readOnly置为true,否则即使隐藏了清空按钮,用户依然可以在输入框里把值delete

<input class="Wdate" type="text" id="d15" onFocus="WdatePicker({isShowClear:false,readOnly:true})"/>
6. 自动选择显示位置
当控件处在页面边界时,它会自动选择显示的位置,所以没有必要担心弹出框会被页面边界遮住的问题了.
7. 自定义弹出位置
当控件处在页面边界时,它会自动选择显示的位置.此外你还可以使用position参数对弹出位置做调整.
示例1-6 通过position属性,自定义弹出位置
使用positon属性指定,弹出日期的坐标为{left:100,top:50}

<input class="Wdate" type="text" id="d16" onfocus="WdatePicker({position:{left:100,top:50}})"/>

position属性的详细用法详见属性表
2. 特功能
1. 平面显示
日期控件支持平面显示功能,只要设置一下eCont属性就可以把它当作日历来使用了,无需触发条件,直接显示在页面上
示例2-1 平面显示演示
<div id="div1"></div>
<script>
WdatePicker({eCont:'div1',onpicked:function(dp){alert('你选择的日期是:'+DateStr())}})
</script>

$DateStr 用法详见内置函数
2. 支持多种容器
除了可以将值返回给input以外,还可以通过配置el属性将值返回给其他的元素(:textarea,div,span),带有innerHTML属性的HTML元素
示例2-2 将日期返回到<span>
2008-01-01

代码:
<span id="demospan">2008-01-01</span>
<img onClick="WdatePicker({el:'demospan'})" src="../../My97DatePicker/skin/datePicker.gif" width="16" height="22" align="absmiddle" />
3. 起始日期功能
注意:日期格式必须与 realDateFmt realTimeFmt 一致
有时在项目中需要选择生日之类的日期,而默认点开始日期都是当前日期,导致年份选择非常麻烦,你可以通过起始日期功能加上配置alwaysUseStartDate属性轻松解决此类问题
示例2-3-1 起始日期简单应用
默认的起始日期为 1980-05-01
当日期框为空值时,将使用 1980-05-01 做为起始日期


<input type="text" id="d221" onFocus="WdatePicker({startDate:'1980-05-01'})"/>
示例2-3-2 alwaysUseStartDate属性应用
默认的起始日期为 1980-05-01
当日期框无论是何值,始终使用 1980-05-01 做为起始日期


<input type="text" id="d222" onFocus="WdatePicker({startDate:'1980-05-01',alwaysUseStartDate:true})"/>
示例2-3-3 使用内置参数
除了使用静态的日期值以外,还可以使用动态参数(:%y,%M分别表示当前年和月)

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


<input type="text" id="d233" onFocus="WdatePicker({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
yyM
083
yyyyMMdd
20080312
今天是:yyyyMd HHmm
今天是:2008312 1920
H:m:s
19:20:0
y
8
示例 2-4-1: 年月日时分秒

<input type="text" id="d241" onfocus="WdatePicker({dateFmt:'yyyyMMdd HHmmss'})" class="Wdate" />
示例 2-4-2 时分秒

<input type="text" id="d242" onfocus="WdatePicker({skin:'whyGreen',dateFmt:'H:mm:ss'})" class="Wdate"/>

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

<input type="text" id="d243" onfocus="WdatePicker({skin:'whyGreen',dateFmt:'yyyyMM'})" class="Wdate"/>
示例 2-4-4 取得系统可识别的日期值(重要)
类似于 199975 这样的日期是不能够被系统识别的,他必须转换为能够识别的类型如 1999-07-05

真实的日期值是:
<input id="d244" type="text" class="Wdate" onfocus="WdatePicker({dateFmt:'yyyyMd',vel:'d244_2'})"/>
<input id="d244_2" type="text" />

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