读书人

My97DatePicker使用论说文档

发布时间: 2012-11-06 14:07:00 作者: rapoo

My97DatePicker使用说明文档

示例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.$ 相当于 document.getElementById?
$dp.$ 的详细用法可以参考内置函数

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

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


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


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


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

  1. 3.???????????支持周显示

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

?

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


<input id="d121" type="text" onfocus="WdatePicker({isShowWeek:true})"/>

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

?? 您选择了第?(W格式)周, 另外您可以使用WW格式:?周?
<input type="text" id="d122" onFocus="WdatePicker({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 用法详见内置函数

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

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

  1. 5.???????????操作按钮自定义

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

示例1-5 禁用清空功能

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

<input type="text" id="d15" onFocus="WdatePicker({isShowClear:false,readOnly:true})"/>

  1. 6.???????????自动选择显示位置

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

  1. 7.???????????自定义弹出位置

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

?

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

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

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

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

2.?特色功能

  1. 1.???????????平面显示

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

?

示例2-1 平面显示演示

<div id="div1"></div>
<script>
WdatePicker({eCont:'div1',onpicked:function(dp){alert('你选择的日期是:'+dp.cal.getDateStr())}})
</script>

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

  1. 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="http://www.cnblogs.com/My97DatePicker/skin/datePicker.gif" width="16" height="22" align="absmiddle" style="cursor:pointer" />

  1. 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})"/>

  1. 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: 年月日时分秒


<input type="text" id="d241" onfocus="WdatePicker({dateFmt:'yyyy年MM月dd日 HH时mm分ss秒'})" style="width:300px"/>

示例?2-4-2?时分秒


<input type="text" id="d242" onfocus="WdatePicker({skin:'whyGreen',dateFmt:'H:mm:ss'})" id="d243" onfocus="WdatePicker({skin:'whyGreen',dateFmt:'yyyy年MM月'})" type="text" onfocus="WdatePicker({dateFmt:'yyyy年M月d日',vel:'d244_2'})"/>
<input id="d244_2" type="text" />

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

  1. 5.???????????编辑功能

当日期框里面有值时,修改完某个属性后,只要点击这个按钮就可以实现时间和日期的编辑

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

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

  1. 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中定义的

  1. 7.???????????跨无限级框架显示

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

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

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

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

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

示例2-8 民国年演示


<input type="text" id="d28" onClick="WdatePicker({dateFmt:'yyy/MM/dd'})"/>

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

  1. 9.???????????为编程带来方便

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

  1. 10.????????其他属性

设置readOnly属性,可指定日期框是否只读?
设置highLineWeekDay属性,可指定是否高亮周末?
设置isShowOthers属性,可指定是否显示其他月的日期?
加上type="text" onFocus="WdatePicker({lang:'zh-tw'})"/>

英文:?
<input id="d312" type="text" onFocus="WdatePicker({lang:'en'})"/>

简体中文:?
<input id="d313" type="text" onFocus="WdatePicker({lang:'zh-cn'})"/>

注意:默认情况lang='auto',即根据浏览器的语言自动选择语言.

  1. 2.???????????自定义和动态切换皮肤?立刻转到皮肤中心

通过skin属性,可以为每个日期控件单独配置皮肤,当然也可以通过WdatePicker.js配置全局的皮肤
皮肤列表和皮肤安装说明详见皮肤配置

示例3-2 皮肤演示

默认皮肤default: skin:'default'

<input id="d321" type="text" onfocus="WdatePicker()"/>

注意:在WdatePicker里配置了skin='default',所以此处可省略,同理,如果你把WdatePicker里的skin配置成'whyGreen'那么在不指定皮肤的情况下都使用'whyGreen'皮肤了


whyGreen皮肤: skin:'whyGreen'?

<input id="d322" type="text" onfocus="WdatePicker({skin:'whyGreen'})"/>

注意:更多皮肤,请到皮肤中心下载

4.?日期范围限制

  1. 1.???????????静态限制
    注意:日期格式必须与 realDateFmt 和 realTimeFmt 一致

你可以给通过配置minDate(最小日期),maxDate(最大日期)为静态日期值,来限定日期的范围

示例4-1-1?限制日期的范围是?2006-09-10到2008-12-20


<input id="d411" type="text" onfocus="WdatePicker({skin:'whyGreen',minDate:'2006-09-10',maxDate:'2008-12-20'})"/>

示例4-1-2?限制日期的范围是 2008-3-8 11:30:00 到 2008-3-10 20:59:30


<input type="text" id="d412" onfocus="WdatePicker({skin:'whyGreen',dateFmt:'yyyy-MM-dd HH:mm:ss',minDate:'2008-03-08 11:30:00',maxDate:'2008-03-10 20:59:30'})" value="2008-03-09 11:00:00"/>

示例4-1-3?限制日期的范围是 2008年2月 到 2008年10月


<input type="text" id="d413" onfocus="WdatePicker({dateFmt:'yyyy年M月',minDate:'2008-2',maxDate:'2008-10'})"/>

示例4-1-4?限制日期的范围是 8:00:00 到 11:30:00


<input type="text" id="d414" onfocus="WdatePicker({dateFmt:'H:mm:ss',minDate:'8:00:00',maxDate:'11:30:00'})"/>

  1. 2.???????????动态限制
    注意:日期格式必须与 realDateFmt 和 realTimeFmt 一致

你可以通过系统给出的动态变量,如%y(当前年),%M(当前月)等来限度日期范围,你还可以通过#{}进行表达式运算,如:#{%d+1}:表示明天

动态变量表

格式

说明

%y

当前年

%M

当前月

%d

当前日

%ld

本月最后一天

%H

当前时

%m

当前分

%s

当前秒

#{}

运算表达式,如:#{%d+1}:表示明天

#F{}

{}之间是函数可写自定义JS代码

示例4-2-1?只能选择今天以前的日期(包括今天)


<input id="d421" type="text" onfocus="WdatePicker({skin:'whyGreen',maxDate:'%y-%M-%d'})"/>

示例4-2-2?使用了运算表达式?只能选择今天以后的日期(不包括今天)


<input id="d422" type="text" onfocus="WdatePicker({minDate:'%y-%M-#{%d+1}'})"/>

示例4-2-3?只能选择本月的日期1号至本月最后一天


<input id="d423" type="text" onfocus="WdatePicker({minDate:'%y-%M-01',maxDate:'%y-%M-%ld'})"/>

示例4-2-4?只能选择今天7:00:00至明天21:00:00的日期


<input id="d424" type="text" onfocus="WdatePicker({dateFmt:'yyyy-M-d H:mm:ss',minDate:'%y-%M-%d 7:00:00',maxDate:'%y-%M-#{%d+1} 21:00:00'})"/>

示例4-2-5?使用了运算表达式?只能选择 20小时前 至 30小时后的日期


<input id="d425" type="text" onClick="WdatePicker({dateFmt:'yyyy-MM-dd HH:mm',minDate:'%y-%M-%d #{%H-20}:%m:%s',maxDate:'%y-%M-%d #{%H+30}:%m:%s'})"/>

  1. 3.???????????脚本自定义限制
    注意:日期格式必须与 realDateFmt 和 realTimeFmt 一致

系统提供了$dp.$D和$dp.$DV这两个API来辅助你进行日期运算,此外你还可以通过在 #F{} 中填入你自定义的脚本,做任何你想做的日期限制

示例4-3-1?前面的日期不能大于后面的日期且两个日期都不能大于?2020-10-01

合同有效期从?到?
<input id="d4311" type="text" onFocus="WdatePicker({maxDate:'#F{$dp.$D(\'d4312\')||\'2020-10-01\'}'})"/>?
<input id="d4312" type="text" onFocus="WdatePicker({minDate:'#F{$dp.$D(\'d4311\')}',maxDate:'2020-10-01'})"/>

注意:
两个日期的日期格式必须相同

$dp.$ 相当于 document.getElementById 函数.
那么为什么里面的 ' 使用 \' 呢? 那是因为 " 和 ' 都被外围的函数使用了,故使用转义符 \ ,否则会提示JS语法错误.
所以您在其他地方使用时注意把 \' 改成 " 或者 ' 来使用.

#F{$dp.$D(\'d4312\')||\'2020-10-01\'} 表示当 d4312 为空时, 采用?2020-10-01?的值作为最大值

示例4-3-2?前面的日期+3天 不能大于 后面的日期

日期从?到?
<input type="text" id="d4321" onFocus="WdatePicker({maxDate:'#F{$dp.$D(\'d4322\',{d:-3});}'})"/>
<input type="text" id="d4322" onFocus="WdatePicker({minDate:'#F{$dp.$D(\'d4321\',{d:3});}'})"/>

使用 $dp.$D 函数 可以将日期框中的值,加上定义的日期差量:
两个参数: id={字符类型}需要处理的文本框的id值 , obj={对象类型}日期差量
日期差量用法:
属性y,M,d,H,m,s分别代表年月日时分秒
如?
为空时,表示直接取值,不做差量(示例4-3-1中的参数就是空的)
{M:5,d:7} 表示 五个月零7天
{y:1,d:-3} 表示 1年少3天
{d:1,H:1} 表示一天多1小时

示例4-3-3?前面的日期+3月零2天 不能大于 后面的日期 且 前面日期都不能大于?2020-4-3减去3月零2天 后面日期 不能大于?2020-4-3

住店日期从?到?
<input type="text" id="d4331" onFocus="WdatePicker({maxDate:'#F{$dp.$D(\'d4332\',{M:-3,d:-2})||$dp.$DV(\'2020-4-3\',{M:-3,d:-2})}'})"/>
<input type="text" id="d4332" onFocus="WdatePicker({minDate:'#F{$dp.$D(\'d4331\',{M:3,d:2});}',maxDate:'2020-4-3'})"/>

注意:
#F{$dp.$D(\'d4332\',{M:-3,d:-2}) || $dp.$DV(\'2020-4-3\',{M:-3,d:-2})}
表示当 d4332 为空时, 采用 $dp.$DV(\'2020-4-3\',{M:-3,d:-2})} 的值作为最大值

使用 $dp.$DV 函数 可以将显式传入的值,加上定义的日期差量:
两个参数: value={字符类型}需要处理的值 , obj={对象类型}日期差量
用法同上面的 $dp.$D 类似,如 $dp.$DV(\'2020-4-3\',{M:-3,d:-2}) 表示?2020-4-3减去3月零2天

示例4-3-4?发挥你的JS才能,定义任何你想要的日期限制

自动转到随机生成的一天,当然,此示例没有实际的用途,只是为演示目的

<script>
//返回一个随机的日期
function randomDate(){
var Y = 2000 + Math.round(Math.random() * 10);
var M = 1 + Math.round(Math.random() * 11);
var D = 1 + Math.round(Math.random() * 27);
return Y+'-'+M+'-'+D;
}
</script>
<input type="text" id="d434" onFocus="var date=randomDate();WdatePicker({minDate:date,maxDate:date})"/>

  1. 4.???????????无效天

可以使用此功能禁用周日至周六所对应的日期,相关属性:disabledDays (0至6 分别代表 周日至周六)

示例4-4-1?禁用 周六 所对应的日期


<input id="d441" type="text" onFocus="WdatePicker({disabledDays:[6]})"/>

示例4-4-2?通过position属性,自定义弹出位置


<input id="d442" type="text" onFocus="WdatePicker({disabledDays:[0,6]})"/>

  1. 5.???????????无效日期
    注意:日期格式必须与 realDateFmt 和 realTimeFmt 一致

可以使用此功能禁用,所指定的一个或多个日期,只要你熟悉正则表达式,你可以尽情发挥

用法(正则匹配):?
如果你熟悉正则表达式,会很容易理解下面的匹配用法
如果不熟悉,可以参考下面的常用示例?
['2008-02-01','2008-02-29'] 表示禁用?2008-02-01?和?2008-02-29
['2008-..-01','2008-02-29'] 表示禁用 2008-所有月份-01 和?2008-02-29
['200[0-8]]-02-01','2008-02-29'] 表示禁用 [2000至2008]-02-01 和?2008-02-29
['^2006'] 表示禁用 2006年的所有日期

此外,您还可以使用 %y %M %d %H %m %s 等变量, 用法同动态日期限制 注意:%ld不能使用
['....-..-01','%y-%M-%d'] 表示禁用 所有年份和所有月份的第一天和今天?
['%y-%M-#{%d-1}','%y-%M-#{%d+1}'] 表示禁用 昨天和明天

当然,除了可以限制日期以外,您还可以限制时间
['....-..-.. 10\:00\:00'] 表示禁用 每天10点 (注意 : 需要 使用 \: )

不再多举例了,尽情发挥你的正则才能吧!

示例4-5-1?禁用 每个月份的 5日 15日 25日


<input id="d451" type="text" onFocus="WdatePicker({disabledDates:['5$']})"/>

注意 :'5$' 表示以 5 结尾 注意 $ 的用法

示例4-5-2?禁用 所有早于2000-01-01的日期


<input id="d452" type="text" onFocus="WdatePicker({disabledDates:['^19']})"/>

注意:'^19' 表示以 19 开头 注意 ^ 的用法?
当然,可以使用minDate实现类似的功能 这里主要是在演示 ^ 的用法

示例4-5-3?配合min/maxDate使用,可以把可选择的日期分隔成多段

本示例本月可用日期分隔成五段 分别是: 1-3 8-10 16-24 26,27 29-月末

<input id="d453" type="text" onFocus="WdatePicker({minDate:'%y-%M-01',maxDate:'%y-%M-%ld',disabledDates:['0[4-7]$','1[1-5]$','2[58]$']})"/>

示例4-5-4?min/maxDate disabledDays disabledDates?配合使用?即使在要求非常苛刻的情况下也能满足需求


<input id="d454" type="text" onFocus="WdatePicker({minDate:'%y-%M-01',maxDate:'%y-%M-%ld',disabledDates:['0[4-7]$','1[1-5]$','2[58]$'],disabledDays:[1,3,6]})"/>

示例4-5-5?禁用前一个小时和后一个小时内所有时间使用 %y %M %d %H %m %s 等变量

鼠标点击 小时输入框时,你会发现当然时间对应的前一个小时和后一个小时是灰色的

<input id="d2a25" type="text" onFocus="WdatePicker({dateFmt:'yyyy-MM-dd HH:mm:ss',disabledDates:['%y-%M-%d #{%H-1}\:..\:..','%y-%M-%d #{%H+1}\:..\:..']})"/>?

注意:%y %M %d等详见动态变量表

示例4-5-6?#F{}也是可以使用的

本示例利用自定义函数 随机禁用0-23中的任何一个小时
打开小时选择框,你会发现有一个小时被禁用的,而且每次禁用的小时都不同
?
<script>
function randomH(){
//产生一个随机的数字 0-23?
var H = Math.round(Math.random() * 23);
if(H<10) H='0'+H;
//返回 '^' + 数字
return '^'+H;
}
</script>
<input type="text" id="d456" onFocus="WdatePicker({dateFmt:'HH:mm:ss',disabledDates:['#F{randomH()}']})"/>

  1. 6.???????????有效天与有效日期

使用无效天和无效日期可以很方便的禁用不可用的日期,但是在只需要启用少部分日期的情况下,有效天和有效日期的功能就非常适合了.
关键属性: opposite 默认为false, 为true时,无效天和无效日期变成有效天和有效日期

示例4-6 只启用 每个月份的 5日 15日 25日


<input id="d46" type="text" onFocus="WdatePicker({opposite:true,disabledDates:['5$']})"/>

注意 :'5$' 表示以 5 结尾 注意 $ 的用法

5.?自定义事件

  1. 1.???????????自定义事件

如果你需要做一些附加的操作,你也不必担心,日期控件自带的自定义事件可以满足你的需求.此外,你还可以在自定义事件中调用提供的API库来做更多的运算和扩展,绝对可以通过很少的代码满足你及其个性化的需求.

注意下面几个重要的指针,将对你的编程带来很多便利
this: 指向文本框
dp: 指向$dp
dp.cal: 指向日期控件对象
注意:函数原型必须使用类似 function(dp){} 的模式,这样子,在函数内部才可以使用dp

  1. 2.???????????onpicking?和 onpicked 事件

示例5-2-1?onpicking事件演示


<input type="text" id="5421" onFocus="WdatePicker({onpicking:function(dp){if(!confirm('日期框原来的值为: '+dp.cal.getDateStr()+', 要覆盖吗?')) return true;}})" type="text" onFocus="var d5222=$dp.$('d5222');WdatePicker({onpicked:function(){d5222.focus();},maxDate:'#F{$dp.$D(\'d5222\')}'})"/>

<input id="d5222" type="text" onFocus="WdatePicker({minDate:'#F{$dp.$D(\'d5221\')}'})"/>

注意:$dp.$是一个内置函数,相当于document.getElementById

示例5-2-3?将选择的值拆分到文本框

年?月?日?时?分?秒??
<input type="text" id="d523_y" size="5"/> 年
<input type="text" id="d523_M" size="3"/> 月
<input type="text" id="d523_d" size="3"/> 日
<input type="text" id="d523_HH" size="3"/> 时
<input type="text" id="d523_mm" size="3"/> 分
<input type="text" id="d523_ss" size="3"/> 秒?
<img onclick="WdatePicker({el:'d523',dateFmt:'yyyy-MM-dd HH:mm:ss',onpicked:pickedFunc})" src="http://www.cnblogs.com/My97DatePicker/skin/datePicker.gif" width="16" height="22" align="absmiddle" style="cursor:pointer"/>
<script>
function pickedFunc(){
$dp.$('d523_y').value=$dp.cal.getP('y');
$dp.$('d523_M').value=$dp.cal.getP('M');
$dp.$('d523_d').value=$dp.cal.getP('d');
$dp.$('d523_HH').value=$dp.cal.getP('H');
$dp.$('d523_mm').value=$dp.cal.getP('m');
$dp.$('d523_ss').value=$dp.cal.getP('s');
}
</script>

注意:el:'d523'中,如果你不需要d523这个框,你可以把他改成hidden,但是el属性必须指定
$dp.$和$dp.cal.getP都是内置函数

  1. 3.???????????onclearing?和 oncleared 事件

示例5-3-1?使用onclearing事件取消清空操作


<input type="text" id="d531" onFocus="WdatePicker({onclearing:function(){if(!confirm('日期框的值为:'+this.value+', 确实要清空吗?'))return true;}})"/>

注意:当onclearing函数返回true时,系统的清空事件将被取消,
函数体里面没有引用$dp,所以函数原型里面可以省略参数dp

示例5-3-2?使用cal对象取得当前日期所选择的月份(使用了 dp.cal)


<input type="text" id="d532" onFocus="WdatePicker({oncleared:function(dp){alert('当前日期所选择的月份为:'+dp.cal.date.M);}})"/>

示例5-3-3?综合使用两个事件

?
<script>
function d533_focus(element){
var clearingFunc = function(){ if(!confirm('日期框的值为:'+this.value+', 确实要清空吗?')) return true; }
var clearedFunc = function(){ alert('日期框已被清空'); }
WdatePicker({el:element,onclearing:clearingFunc,oncleared:clearedFunc})
}
</script>
<input type="text" id="d533" onFocus="d533_focus(this)"/>

6.?快速选择功能

此功能允许指定5个最常用的日期,可以方便用户选择,如果不指定,系统将自动生成
相关属性:
qsEnabled 是否启用快速选择功能?
quickSel 快速选择数据,可以传入5个快速选择日期,日期格式同min/maxDate

注意:
日期格式必须与 realDateFmt realTimeFmt 相匹配
除了使用静态的日期值以外,还可以使用动态参数(如:%y,%M分别表示当前年和月)

示例6-1?传入2个静态日期


<input type="text" onfocus="WdatePicker({dateFmt:'yyyy年MM月dd日',qsEnabled:true,quickSel:['2000-1-10','2000-2-20']})"/>

注意:当传入的数据不足5个时,系统将自动补全

示例6-2?传入2个动态日期,1个静态日期


<input type="text" onFocus="WdatePicker({dateFmt:'yyyy年MM月dd日',qsEnabled:true,quickSel:['2000-10-01','%y-%M-01','%y-%M-%ld']})"/>

注意:当传入的数据不足5个时,系统将自动补全

.?配置说明

1.?属性配置

  1. 1.???????????属性表

属性

类型

默认值

说明

静态属性:只能在WdatePicker.js中配置,一般情况下,不建议您修改静态属性的值

$wdate

bool

true

是否自动引入Wdate类 设置为true时,可直接在引入WdatePicker.js的页面里使用 type="text/javascript" src="datepicker/WdatePicker.js"></script>
注:src="datepicker/WdatePicker.js" 请根据你的实际情况改变路径

2. 加上主调函数 WdatePicker
关于 WdatePicker 的用法:

如果您是新手,对js还不是很了解的话一定要多看看这份文档
基本上每一个演示的示例下面都有相关代码,并且 关键属性用蓝字标出,关键值用红字标出 应该很容易看明白?

如果您有一定的水准
希望能从头到尾把功能介绍好好看一遍,这样大部分功能你都会用了

如果您是高手
建议您通读配置说明和内置函数

.?内置函数

函数名

返回值类型

作用域

参数

描述

$dp.$

Element

全局

el [string]: 对象的ID

相当于document.getElementById
参考 示例?1-1-2

$dp.show

void

全局

显示日期选择框

$dp.hide

void

全局

隐藏日期选择框

$dp.$D

String

全局

id [string]: 对象的ID?
arg [object]: 日期差量,可以设置成
{y:[值],M:[值],d:[值],H:[值],m:[值],s:[值]}
属性 y,M,d,H,m,s 分别代表 年月日时分秒
{M:3,d:7} 表示 3个月零7天
{d:1,H:1} 表示1天多1小时

将id对应的日期框中的日期字符串,加上定义的日期差量,返回使用real格式化后的日期串
参考 示例?4-3-2

$dp.$DV

String

全局

v [string]: 日期字符串
arg [object]: 同上例的arg

将传入的日期字符串,加上定义的日期差量,返回使用real格式化后的日期串
参考 示例?4-3-3

以下函数只在事件自定义函数中有效

$dp.cal.getP

String

事件function

p [string]: 属性名称 yMdHmswWD分别代表年,月,日,时,分,秒,星期(0-6),周(1-52),星期(一-六)?
f [string]: format 格式字符串
设置方法参考 1.4 自定义格式

返回所指定属性被格式字符串格式化后的值[单属性]
参考 示例?1-2-2

dp.cal.getDateStr

String

事件function

f [string]: 格式字符串,为空时使用dateFmt

返回所指定属性被格式字符串格式化后的值[整个值]

完善中

完善中

完善中

完善中

完善中

.?疑难解答

任何问题,请先参考?技术支持?
如果找不到答案,您可以直接在blog留言,或者通过下面的联系方式与我联系

.?联系My97

* 如果您在使用过程中遇到问题,或者有更好的建议
* 欢迎您访问
* BLOG:?http://my97.cnblogs.com
* MAIL:?smallcarrot@163.com
* 有问题在我blog留言或给我Email吧,最好先仔细看说明,很多问题都是因为没有仔细看说明导致的

? 2008?My97?All Rights Reserved.

久久基地 http://www.99base.com/ 网络编程交流学习,欢迎大家的加入

读书人网 >Web前端

热点推荐