http://www.my97.net/dp/index.asp
目前的版本是:4.7
IE 6.0+ , Firefox 2.0+ , Chrome, Opera 9.5+ , Safari 3.0+
除了支持常规在input单击或获得焦点调用外,还支持使用其他的元素如:<img><div>等触发WdatePicker函数来调用弹出日期框
<input id="d11" type="text" onClick="WdatePicker()"/>
<input id="d12" type="text"/><img οnclick="WdatePicker({el:'d12'})" src="../skin/datePicker.gif" width="16" height="22" align="absmiddle">注意:只需要传入控件的id即可
下拉,输入,导航选择日期年月时分秒输入框都具备以下三种特性1. 通过导航图标选择2. 直接使用键盘输入数字3. 直接从弹出的下拉框中选择另:年份输入框有智能提示功能,当用户连续点击同一个导航按钮5次时,会自动弹出年份下拉框
支持周显示可以通过配置isShowWeek属性决定是否限制周,并且在返回日期的时候还可以通过自带的自定义事件和API函数返回选择的周
<input id="d121" type="text" οnfοcus="WdatePicker({isShowWeek:true})"/>注意:周算法参考的是ISO8601定义的方法,如果您对此有疑问,请详见:http://en.wikipedia.org/wiki/ISO_week_date周算法选择(4.7新增)相关属性:whichDayIsfirstWeek周算法不同的地方有一些差异常见算法有三种1. ISO8601:规定第一个星期四为第一周,默认值: 42. MSExcel:1月1日所在的周: 可以填写: 73. 自己根据需要自定义,每年的第一个星期X作为第一周,可以填写: X (X可以是1-7之间任何一个数字)
您选择了第 (W格式)周, 另外您可以使用WW格式: 周<input type="text" class="Wdate" 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 用法详见内置函数和属性
只读开关,高亮周末功能设置readOnly属性 true 或 false 可指定日期框是否只读设置highLineWeekDay属性 ture 或 false 可指定是否高亮周末
操作按钮自定义清空按钮和今天按钮,可以根据需要进行自定义,它们分别对应 isShowClear 和 isShowToday 默认值都是true
最好把readOnly置为true,否则即使隐藏了清空按钮,用户依然可以在输入框里把值delete掉<input class="Wdate" type="text" id="d15" onFocus="WdatePicker({isShowClear:false,readOnly:true})"/>
自动选择显示位置当控件处在页面边界时,它会自动选择显示的位置,所以没有必要担心弹出框会被页面边界遮住的问题了.
自定义弹出位置当控件处在页面边界时,它会自动选择显示的位置.此外你还可以使用position参数对弹出位置做调整.
使用positon属性指定,弹出日期的坐标为{left:100,top:50}<input class="Wdate" type="text" id="d16" οnfοcus="WdatePicker({position:{left:100,top:50}})"/>position属性的详细用法详见属性表
自定义星期的第一天(4.6新增)各个国家的习惯不同,有些喜欢以星期日作为第一天,有些以星期一作为第一天.相关属性:firstDayOfWeek: 可设置 0 - 6 的任意一个数字,0:星期日 1:星期一 以此类推
<input class="Wdate" type="text" id="d17" οnfοcus="WdatePicker({firstDayOfWeek:1})"/>
日期控件支持平面显示功能,只要设置一下eCont属性就可以把它当作日历来使用了,无需触发条件,直接显示在页面上
<div id="div1"></div><script>WdatePicker({eCont:'div1',onpicked:function(dp){alert('你选择的日期是:'+dp.cal.getDateStr())}})</script>$dp.cal.getDateStr 用法详见内置函数和属性
支持多种容器除了可以将值返回给input以外,还可以通过配置el属性将值返回给其他的元素(如:textarea,div,span)等,带有innerHTML属性的HTML元素
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" style="cursor:pointer" />
起始日期功能 注意:日期格式必须与 realDateFmt 和 realTimeFmt 一致有时在项目中需要选择生日之类的日期,而默认点开始日期都是当前日期,导致年份选择非常麻烦,你可以通过起始日期功能加上配置alwaysUseStartDate属性轻松解决此类问题
默认的起始日期为 1980-05-01当日期框为空值时,将使用 1980-05-01 做为起始日期<input type="text" id="d221" onFocus="WdatePicker({startDate:'1980-05-01'})"/>
默认的起始日期为 1980-05-01当日期框无论是何值,始终使用 1980-05-01 做为起始日期<input type="text" id="d222" onFocus="WdatePicker({startDate:'1980-05-01',alwaysUseStartDate:true})"/>
除了使用静态的日期值以外,还可以使用动态参数(如:%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})"/>
自定义格式yMdHmswW分别代表年月日时分秒星期周,你可以任意组合这些元素来自定义你个性化的日期格式.
日期格式表 格式说明y将年份表示为最多两位数字。如果年份多于两位数,则结果中仅显示两位低位数。yy同上,如果小于两位数,前面补零。yyy将年份表示为三位数字。如果少于三位数,前面补零。yyyy将年份表示为四位数字。如果少于四位数,前面补零。M将月份表示为从 1 至 12 的数字MM同上,如果小于两位数,前面补零。MMM返回月份的缩写 一月 至 十二月 (英文状态下 Jan to Dec) 。MMMM返回月份的全称 一月 至 十二月 (英文状态下 January to December) 。d将月中日期表示为从 1 至 31 的数字。dd同上,如果小于两位数,前面补零。H将小时表示为从 0 至 23 的数字。HH同上,如果小于两位数,前面补零。m将分钟表示为从 0 至 59 的数字。mm同上,如果小于两位数,前面补零。s将秒表示为从 0 至 59 的数字。ss同上,如果小于两位数,前面补零。w返回星期对应的数字 0 (星期天) - 6 (星期六) 。D返回星期的缩写 一 至 六 (英文状态下 Sun to Sat) 。DD返回星期的全称 星期一 至 星期六 (英文状态下 Sunday to Saturday) 。W返回周对应的数字 (1 - 53) 。WW同上,如果小于两位数,前面补零 (01 - 53) 。示例 格式字符串值yyyy-MM-dd HH:mm:ss2008-03-12 19:20:00yy年M月08年3月yyyyMMdd20080312今天是:yyyy年M年d HH时mm分今天是:2008年3月12日 19时20分H:m:s19:20:0y年8年MMMM d, yyyy三月 12, 2008<input type="text" id="d241" οnfοcus="WdatePicker({dateFmt:'yyyy年MM月dd日 HH时mm分ss秒'})" class="Wdate" style="width:300px"/>注意:点两次才能选择日期的原因,详见 autoPickDate 属性
<input type="text" id="d242" οnfοcus="WdatePicker({skin:'whyGreen',dateFmt:'H:mm:ss'})" class="Wdate"/>注意:这里提前使用了皮肤(skin)属性,所以你会看到一个不同的皮肤,皮肤属性详见自定义和动态切换皮肤
<input type="text" id="d243" οnfοcus="WdatePicker({skin:'whyGreen',dateFmt:'yyyy年MM月'})" class="Wdate"/>
类似于 1999年7月5日 这样的日期是不能够被系统识别的,他必须转换为能够识别的类型如 1999-07-05 真实的日期值是: <input id="d244" type="text" class="Wdate" οnfοcus="WdatePicker({dateFmt:'yyyy年M月d日',vel:'d244_2'})"/><input id="d244_2" type="text" />注意:在实际应用中,一般会把vel指定为一个hidden控件,这里是为了把真实值展示出来,所以使用文本框关键属性: vel 指定一个控件或控件的ID,必须具有value属性(如input),用于存储真实值(也就是realDateFmt和realTimeFmt格式化后的值)
<input type="text" id="d245" οnfοcus="WdatePicker({dateFmt:'DD, MMMM d, yyyy'})" class="Wdate"/>
双月日历功能(4.6新增)可以同时弹出两个月的日历
<input class="Wdate" type="text" οnfοcus="WdatePicker({doubleCalendar:true,dateFmt:'yyyy-MM-dd'})"/>注意:双月日历一般只用于包含年月日三个元素的场景,另外设置该属性时,autoPickDate自动设置为true
自动纠错功能纠错处理可设置为3种模式:提示(默认) 自动纠错 标记,当日期框中的值不符合格式时,系统会尝试自动修复,如果修复失败会根据您设置的纠错处理模式进行处理,错误判断功能非常智能它可以保证用户输入的值是一个合法的值
请在下面的日期框中填入一个不合法的日期(如:1997-02-29),再尝试离开焦点使用默认容错模式 提示模式 errDealMode = 0 在输入错误日期时,会先提示注意:1997年不是闰年哦
最大日期是2000-01-10 ,如果在下框中填入的日期 大于 2000-01-10(如2000-01-12)也会被认为是不合法的日期自动纠错模式 errDealMode = 1 在输入错误日期时,自动恢复前一次正确的值
如:2008-02-20 无效日期限制2008-02-02 2008-02-09 2008-02-16 2008-02-23 无效天限制都是无效日期您可以尝试在下框中输入这些日期,并离开焦点标记模式 errDealMode = 2 在输入错误日期时,不做提示和更改,只是做一个标记,但此时日期框不会马上隐藏注意:标记类:WdateFmtErr是在skin目录下WdatePicker.css中定义的
跨无限级框架显示无论你把日期控件放在哪里,你都不需要担心会被外层的iframe所遮挡进而影响客户体验,因为My97日期控件是可以跨无限级框架显示的
内嵌框架1:
格式为:yyyy-MM-dd HH:mm
可以遮住DropDownList
可无限跨越框架iframe,无论怎么嵌套框架都不必担心了,即使有滚动条也不怕注意:Javascript是无法跨越frameset的,但是My97日期控件可无限跨越框架iframe,任何的frameset都可以使用iframe代替
民国年日历和其他特殊日历当年份格式设置为yyy格式时,利用年份差量属性yearOffset(默认值1911民国元年),可实现民国年日历和其他特殊日历
<input type="text" id="d28" onClick="WdatePicker({dateFmt:'yyy/MM/dd'})"/>注意:年份格式设置成yyy时,真正的日期将会减去一个差量yearOffset(默认值为:1911),如果是民国年使用默认值即可无需另外配置,如果是其他的差量,可以通过参数的形式配置
编辑功能当日期框里面有值时,修改完某个属性后,只要点击这个按钮就可以实现时间和日期的编辑
您可以尝试对下面框中的月份改为1,然后点击更新,你会发现日期由 2000-02-29 01:00:00 变为 2000-01-29 01:00:00
为编程带来方便如果el的值是this,可省略,即所有的el:this都可以不写日期框设置为disabled时,禁止更改日期(不弹出选择框)如果没有定义onpicked事件,自动触发文本框的onchange事件如果没有定义oncleared事件,清空时,自动触发onchange事件
其他属性设置readOnly属性,可指定日期框是否只读设置highLineWeekDay属性,可指定是否高亮周末设置isShowOthers属性,可指定是否显示其他月的日期加上class="Wdate"就会在选择框右边出现日期图标
通过lang属性,可以为每个日期控件单独配置语言,当然也可以通过WdatePicker.js配置全局的语言语言列表和语言安装说明详见语言配置
繁体中文: <input id="d311" class="Wdate" type="text" onFocus="WdatePicker({lang:'zh-tw'})"/>
英文: <input id="d312" class="Wdate" type="text" onFocus="WdatePicker({lang:'en'})"/>
简体中文: <input id="d313" class="Wdate" type="text" onFocus="WdatePicker({lang:'zh-cn'})"/>注意:默认情况lang='auto',即根据浏览器的语言自动选择语言.技巧:很多项目中,可能有固定的语言选项,希望可以在日期选择的属性设置中强制某种语言,即:可以通过后台代码控制语言的选择,其实这个实现起来是很容易的,My97Datepicker是支持多个配置文件共存的,你可以配置类似cn_WdatePicker.js,en_WdatePicker.js(注意命名规则,必须以WdatePicker.js结尾)等等,在这些WdatePicker.js里面设置不同的默认语言,皮肤,格式等其他可以设置的参数,然后在页面里根据你的系统变量引入不同的xx_WdatePicker.js即可
自定义和动态切换皮肤 立刻转到皮肤中心通过skin属性,可以为每个日期控件单独配置皮肤,当然也可以通过WdatePicker.js配置全局的皮肤皮肤列表和皮肤安装说明详见皮肤配置
默认皮肤default: skin:'default'<input id="d321" class="Wdate" type="text" οnfοcus="WdatePicker()"/>注意:在WdatePicker里配置了skin='default',所以此处可省略,同理,如果你把WdatePicker里的skin配置成'whyGreen'那么在不指定皮肤的情况下都使用'whyGreen'皮肤了
whyGreen皮肤: skin:'whyGreen' <input id="d322" class="Wdate" type="text" οnfοcus="WdatePicker({skin:'whyGreen'})"/>注意:更多皮肤,请到皮肤中心下载
你可以给通过配置minDate(最小日期),maxDate(最大日期)为静态日期值,来限定日期的范围
<input id="d411" class="Wdate" type="text" οnfοcus="WdatePicker({skin:'whyGreen',minDate:'2006-09-10',maxDate:'2008-12-20'})"/>
<input type="text" class="Wdate" id="d412" οnfοcus="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"/>
<input type="text" class="Wdate" id="d413" οnfοcus="WdatePicker({dateFmt:'yyyy年M月',minDate:'2008-2',maxDate:'2008-10'})"/>
<input type="text" class="Wdate" id="d414" οnfοcus="WdatePicker({dateFmt:'H:mm:ss',minDate:'8:00:00',maxDate:'11:30:00'})"/>
动态限制注意:日期格式必须与 realDateFmt 和 realTimeFmt 一致你可以通过系统给出的动态变量,如%y(当前年),%M(当前月)等来限度日期范围,你还可以通过{}进行表达式运算,如:{%d+1}:表示明天动态变量表
格式说明%y当前年%M当前月%d当前日%ld本月最后一天%H当前时%m当前分%s当前秒{}运算表达式,如:{%d+1}:表示明天#F{}{}之间是函数可写自定义JS代码<input id="d421" class="Wdate" type="text" οnfοcus="WdatePicker({skin:'whyGreen',maxDate:'%y-%M-%d'})"/>
<input id="d422" class="Wdate" type="text" οnfοcus="WdatePicker({minDate:'%y-%M-{%d+1}'})"/>
<input id="d423" class="Wdate" type="text" οnfοcus="WdatePicker({minDate:'%y-%M-01',maxDate:'%y-%M-%ld'})"/>
<input id="d424" class="Wdate" type="text" οnfοcus="WdatePicker({dateFmt:'yyyy-M-d H:mm:ss',minDate:'%y-%M-%d 7:00:00',maxDate:'%y-%M-{%d+1} 21:00:00'})"/>
<input id="d425" class="Wdate" 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'})"/>
脚本自定义限制注意:日期格式必须与 realDateFmt 和 realTimeFmt 一致系统提供了$dp.$D和$dp.$DV这两个API来辅助你进行日期运算,此外你还可以通过在 #F{} 中填入你自定义的脚本,做任何你想做的日期限制
合同有效期从 到 <input id="d4311" class="Wdate" type="text" onFocus="WdatePicker({maxDate:'#F{$dp.$D(\'d4312\')||\'2020-10-01\'}'})"/><input id="d4312" class="Wdate" type="text" onFocus="WdatePicker({minDate:'#F{$dp.$D(\'d4311\')}',maxDate:'2020-10-01'})"/>注意:两个日期的日期格式必须相同$dp.$ 相当于 document.getElementByIdx_x 函数.那么为什么里面的 ' 使用 \' 呢? 那是因为 " 和 ' 都被外围的函数使用了,故使用转义符 \ ,否则会提示JS语法错误.所以您在其他地方使用时注意把 \' 改成 " 或者 ' 来使用.#F{$dp.$D(\'d4312\')||\'2020-10-01\'} 表示当 d4312 为空时, 采用 2020-10-01 的值作为最大值
日期从 到 <input type="text" class="Wdate" id="d4321" onFocus="WdatePicker({maxDate:'#F{$dp.$D(\'d4322\',{d:-3});}'})"/><input type="text" class="Wdate" 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小时
住店日期从 到 <input type="text" class="Wdate" 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" class="Wdate" 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天
自动转到随机生成的一天,当然,此示例没有实际的用途,只是为演示目的<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" class="Wdate" id="d434" onFocus="var date=randomDate();WdatePicker({minDate:date,maxDate:date})"/>
无效天可以使用此功能禁用周日至周六所对应的日期,相关属性:disabledDays (0至6 分别代表 周日至周六)
<input id="d441" type="text" class="Wdate" onFocus="WdatePicker({disabledDays:[6]})"/>
<input id="d442" type="text" class="Wdate" onFocus="WdatePicker({disabledDays:[0,6]})"/>
无效日期注意:日期格式必须与 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点 (注意 : 需要 使用 \: )
不再多举例了,尽情发挥你的正则才能吧!
<input id="d451" type="text" class="Wdate" onFocus="WdatePicker({disabledDates:['5$']})"/>注意 :'5$' 表示以 5 结尾 注意 $ 的用法
<input id="d452" type="text" class="Wdate" onFocus="WdatePicker({disabledDates:['^19']})"/>注意:'^19' 表示以 19 开头 注意 ^ 的用法当然,可以使用minDate实现类似的功能 这里主要是 在演示 ^ 的用法
本示例本月可用日期分隔成五段 分别是: 1-3 8-10 16-24 26,27 29-月末 <input id="d453" type="text" class="Wdate" onFocus="WdatePicker({minDate:'%y-%M-01',maxDate:'%y-%M-%ld',disabledDates:['0[4-7]$','1[1-5]$','2[58]$']})"/>
<input id="d454" type="text" class="Wdate" onFocus="WdatePicker({minDate:'%y-%M-01',maxDate:'%y-%M-%ld',disabledDates:['0[4-7]$','1[1-5]$','2[58]$'],disabledDays:[1,3,6]})"/>
鼠标点击 小时输入框时,你会发现当然时间对应的前一个小时和后一个小时是灰色的 <input id="d2a25" type="text" class="Wdate" onFocus="WdatePicker({dateFmt:'yyyy-MM-dd HH:mm:ss',disabledDates:['%y-%M-%d {%H-1}\:..\:..','%y-%M-%d {%H+1}\:..\:..']})"/>注意:%y %M %d等详见动态变量表
本示例利用自定义函数 随机禁用0-23中的任何一个小时打开小时选择框,你会发现有一个小时被禁用的,而且每次禁用的小时都不同 <script>function randomH(){//产生一个随机的数字 0-23var H = Math.round(Math.random() * 23);if(H<10) H='0'+H;//返回 '^' + 数字return '^'+H;}</script><input type="text" class="Wdate" id="d456" onFocus="WdatePicker({dateFmt:'HH:mm:ss',disabledDates:['#F{randomH()}']})"/>
有效天与有效日期使用无效天和无效日期可以很方便的禁用不可用的日期,但是在只需要启用少部分日期的情况下,有效天和有效日期的功能就非常适合了.关键属性: opposite 默认为false, 为true时,无效天和无效日期变成有效天和有效日期
<input id="d46" type="text" class="Wdate" onFocus="WdatePicker({opposite:true,disabledDates:['5$']})"/>注意 :'5$' 表示以 5 结尾 注意 $ 的用法
特殊天和特殊日期特殊天和特殊日期的用法跟完全无效天和无效日期完全相同,但是opposite属性对其无效关键属性:specialDays (0至6 分别代表 周日至周六) 用法同无效天specialDates 用法同无效日期,但是对时分秒无效
<input id="d471" type="text" class="Wdate" onFocus="WdatePicker({specialDays:[1,5]})"/>
<input id="d472" type="text" class="Wdate" onFocus="WdatePicker({specialDates:['....-..-01','....-..-15']})"/>
5. 自定义事件
自定义事件如果你需要做一些附加的操作,你也不必担心,日期控件自带的自定义事件可以满足你的需求.此外,你还可以在自定义事件中调用提供的API库来做更多的运算和扩展,绝对可以通过很少的代码满足你及其个性化的需求.注意下面几个重要的指针,将对你的编程带来很多便利this: 指向文本框dp: 指向$dpdp.cal: 指向日期控件对象注意:函数原型必须使用类似 function(dp){} 的模式,这样子,在函数内部才可以使用dp
onpicking 和 onpicked 事件<input type="text" id="5421" onFocus="WdatePicker({onpicking:function(dp){if(!confirm('日期框原来的值为: '+dp.cal.getDateStr()+', 要用新选择的值:' + dp.cal.getNewDateStr() + '覆盖吗?')) return true;}})" class="Wdate"/>注意:你注意到dp.cal.getDateStr和dp.cal.getNewDateStr的用法了嘛? 详见内置函数和属性
选择第一个日期的时候,第二个日期选择框自动弹出日期从: 至 注意:下面第一个控件代码的写法<input id="d5221" class="Wdate" type="text" onFocus="var d5222=$dp.$('d5222');WdatePicker({onpicked:function(){d5222.focus();},maxDate:'#F{$dp.$D(\'d5222\')}'})"/>至<input id="d5222" class="Wdate" type="text" onFocus="WdatePicker({minDate:'#F{$dp.$D(\'d5221\')}'})"/>注意:$dp.$是一个内置函数,相当于document.getElementByIdx_x
年 月 日 时 分 秒 <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 οnclick="WdatePicker({el:'d523',dateFmt:'yyyy-MM-dd HH:mm:ss',onpicked:pickedFunc})" src="../../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都是内置函数
onclearing 和 oncleared 事件<input type="text" class="Wdate" id="d531" onFocus="WdatePicker({onclearing:function(){if(!confirm('日期框的值为:'+this.value+', 确实要清空吗?'))return true;}})"/>注意:当onclearing函数返回true时,系统的清空事件将被取消,函数体里面没有引用$dp,所以函数原型里面可以省略参数dp
<input type="text" class="Wdate" id="d532" onFocus="WdatePicker({oncleared:function(dp){alert('当前日期所选择的月份为:'+dp.cal.date.M);}})"/>
<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" class="Wdate" id="d533" onFocus="d533_focus(this)"/>
年月日时分秒的 changing和changed年月日时分秒都有对应的changing和changed事件,分别是:ychanging ychangedMchanging Mchangeddchanging dchangedHchanging Hchangedmchanging mchangedschanging schanged
<input type="text" class="Wdate" onFocus="WdatePicker({dchanging:cDayFunc, Mchanging:cMonthFunc, ychanging:cYearFunc, dchanged:cDayFunc, Mchanged:cMonthFunc,ychanged:cYearFunc})"/><script>function cDayFunc(){cFunc('d');}function cMonthFunc(){cFunc('M');}function cYearFunc(){cFunc('y');}function cFunc(who){var str,p,c = $dp.cal;if(who=='y'){str='年份';p='y';}else if(who=='M'){str='月份';p='M';}else if(who=='d'){str='日期';p='d';}alert(str+'发生改变了!\n$dp.cal.date.'+p+'='+c.date[p]+'\n$dp.cal.newdate.'+p+'='+c.newdate[p]);}</script>这个例子用到了 $dp.cal.date 和 $dp.cal.newdate 属性,你能从这里发现他们的不同之处吗?下面是有关这两个属性的描述详见内置函数和属性
通过配置WdatePicker.js的属性可以避免每次调用都传入配置值,为变成带来很多方便.在默认情况下My97为每个属性都配置了默认值,这些默认值都可以在WdatePicker.js中修改的你可以根据你个人的喜好更改这些值比如你比较不喜欢默认的皮肤default 而更喜欢 whyGreen 这个皮肤,你可以直接在WdatePicker.js把skin值改为 whyGreen这样,你就不必每次调用控件的时候都传入 skin:'whyGreen' 了你学会了吗?
配置单个控件在控件里面你可以使用 onfocus 或 onclick 事件来调用WdatePicker函数来触发日期控件WdatePicker({})其中{}中的内容都是只对当前实例有效,你可以任意配置属性表里有的所有属性你可以随意的组合这些属性,达到你的需求My97日期控件在这方面是做得非常灵活的.
多套配置快速切换您可以设置多个WdatePicker.js文件,如 cn_WdatePicker.js,en_WdatePicker.js,simple_WdatePicker.js等在不同的页面引入不同的 WdatePicker.js 达到配置快速切换的目的.注意:文件必须以 _WdatePicker.js(大小写不限制) 为后缀,形如 <yourname>_WdatePicker.js
My97DatePicker目录下有个config.js,里面有段代码:var langList =[{name:'en', charset:'UTF-8'},{name:'zh-cn', charset:'gb2312'},{name:'zh-tw', charset:'GBK'}];这就是语言列表,每个项有name和charset两个属性.name 表示语言的名称(必须与浏览器的语言字符串命名相同),在配置的时候,lang属性只能是配置列表里面已有的项,否则将自动返回第一项charset 表示对应语言目录下的js文件所对应的编码格式
语言安装说明分两步轻松实现:1 将语言文件拷贝到 lang 目录2 打开 config.js 配置语言列表
My97DatePicker目录下有个config.js,里面有段代码:var skinList =[{name:'default', charset:'gb2312'},{name:'whyGreen', charset:'gb2312'},{name:'blue', charset:'gb2312'},{name:'simple', charset:'gb2312'}];这就是皮肤列表,每个项有name和charset两个属性.name 表示皮肤的名称,在配置的时候,skin属性只能是配置列表里面已有的项,否则将自动返回第一项charset 表示对应皮肤目录下的css文件:datepicker.css所对应的编码格式
皮肤安装说明分两步轻松实现:1 将皮肤文件包拷贝到 skin 目录2 打开 config.js 配置皮肤列表注意:安装过多的皮肤会影响性能,一般只安装自己使用的皮肤,3个以下比较适宜
1. 在使用该日期控件的文件中加入JS库(仅这一个文件即可,其他文件会自动引入,请勿删除或改名), 代码如下 <script language="javascript" type="text/javascript" src="datepicker/WdatePicker.js"></script>注:src="datepicker/WdatePicker.js" 请根据你的实际情况改变路径2. 加上主调函数 WdatePicker关于 WdatePicker 的用法:如果您是新手,对js还不是很了解的话一定要多看看这份文档基本上每一个演示的示例下面都有相关代码,并且 关键属性用蓝字标出,关键值用红字标出 应该很容易看明白如果您有一定的水准希望能从头到尾把功能介绍好好看一遍,这样大部分功能你都会用了
转载于:https://www.cnblogs.com/w-wfy/p/5846339.html
相关资源:jsp页面使用My97DatePicker日历控件就经常出现无法打开站点