天天看点

wdatePicker 日期插件,备份记录

演示和文档主页:http://www.my97.net/dp/demo/

1、注意事项:      My97DatePicker目录是一个整体,不可破坏里面的目录结构。      将整个My97DatePicker文件夹引入。       2、 常规功能          a、常规调用 [javascript]  view plain copy

  1. <input id="d121" type="text" οnfοcus="WdatePicker({isShowWeek:true})"/>  

   b、图标触发 在WdatePicker()中传入控件的id [javascript]  view plain copy

  1. <span style="white-space:pre">      </span> <input id="d12" type="text"/>  
  2.         <img οnclick="WdatePicker({el:'d12'})" src="js/My97DatePicker/skin/datePicker.gif" width="16" height="22" align="absmiddle">  

c、周显示

配置isShowWeek属性决定是否限制周,并且在返回日期的时候可以在自定义的事件中返回周 [javascript]  view plain copy

  1. <span style="white-space:pre">      </span><input id="d121" type="text" οnfοcus="WdatePicker({isShowWeek:true})"/>  

利用onpicked事件将周赋值给其他文本框

[javascript]  view plain copy

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

[javascript]  view plain copy

  1. 格式一:<input type="text" id="122_1"/>   格式二:<input type="text" id="122_2">    

4、只读开关,高亮显示周末: readOnly: hignLineWeekDay: 5、操作按钮: isShowClear: 清空按钮,默认true iisShowToday:今天按钮,默认true  6、弹出位置: 使用position参数对位置进行设置: [javascript]  view plain copy

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

7、自定义星期的第一天: firstDayOfWeek: 0表示星期天,1表示星期一 [javascript]  view plain copy

  1. <input class="Wdate" type="text" id="d17" οnfοcus="WdatePicker({firstDayOfWeek:1})"/>  

8、平面显示 平面显示功能就是当作桌面日历,通过eCont属性设置,eCont值为要现实的位置 [javascript]  view plain copy

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

9、将日期返回到指定位置 [javascript]  view plain copy

  1. <span id="demospan">2008-01-01</span>   
  2. <img onClick="WdatePicker({el:'demospan'})" src="../../My97DatePicker/skin/datePicker.gif" width="16" height="22" align="absmiddle" style="cursor:pointer" />  

此处 ,可设置2008-01-01为动态的值,如:使用jQuery获取当前时间: [javascript]  view plain copy

  1. jQuery(document).ready(function(){  
  2.     var date=new Date();  
  3. jQuery("#demospan").val(date);  
  4. });  

10、起止日期: a、当日期值为空时,使用指定值作为起始时间: [javascript] view plain copy

  1. <input type="text" id="d221" onFocus="WdatePicker({startDate:'1980-05-01'})"/>  

b、无论日期值为何值,都使用指定值为起始时间: [javascript] view plain copy

  1. <input type="text" id="d222" onFocus="WdatePicker({startDate:'1980-05-01',alwaysUseStartDate:true})"/>  

c、使用动态参数,%y指当年, %M指当月 [javascript] view plain copy

  1. <input type="text" id="d233" onFocus="WdatePicker({startDate:'%y-%M-01 00:00:00',dateFmt:'yyyy-MM-dd HH:mm:ss',alwaysUseStartDate:true})"/>  

dateFmt指定日期的格式:

wdatePicker 日期插件,备份记录

d、获取系统能够识别的时间格式: 实际应用中,会把vel指定为一个hidden控件。 [javascript] view plain copy

  1. <input id="d244" type="text" class="Wdate" οnfοcus="WdatePicker({dateFmt:'yyyy年M月d日',vel:'d244_2'})"/>  
  2. <input id="d244_2" type="text" />  

e、双月日历显示: [javascript] view plain copy

  1. <input class="Wdate" type="text" οnfοcus="WdatePicker({doubleCalendar:true,dateFmt:'yyyy-MM-dd'})"/>  

doubleCalendar,设置是否是双月日历

11、日期范围限制 a、静态限制 2006-09-10到2008-12-20 [javascript] view plain copy

  1. <input id="d411" class="Wdate" type="text" οnfοcus="WdatePicker({skin:'whyGreen',minDate:'2006-09-10',maxDate:'2008-12-20'})"/>  

2008-03-08 11:30:00到2008-03-09 11:00:00 [javascript] view plain copy

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

b、动态限制

wdatePicker 日期插件,备份记录

今天以前: [javascript] view plain copy

  1. <input id="d421" class="Wdate" type="text" οnfοcus="WdatePicker({skin:'whyGreen',maxDate:'%y-%M-%d'})"/>  

今天以后: [javascript] view plain copy

  1. <input id="d422" class="Wdate" type="text" οnfοcus="WdatePicker({minDate:'%y-%M-{%d+1}'})"/>  

本月: [javascript] view plain copy

  1. <input id="d423" class="Wdate" type="text" οnfοcus="WdatePicker({minDate:'%y-%M-01',maxDate:'%y-%M-%ld'})"/>  

今天7时到明天21时: [javascript] view plain copy

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

20小时前到30小时后: [javascript] view plain copy

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

前面值小于后面值: 前后日期格式必须一致,其中,$dp.$相当于document.getElementById(); #F{$dp.$D(\'d4312\')||\'2020-10-01\'}表示当d4312为空时,采用2020-10-01的值作为最大值

[javascript]  view plain copy

  1. <input id="d4311" class="Wdate" type="text" onFocus="WdatePicker({maxDate:'#F{$dp.$D(\'d4312\')||\'2020-10-01\'}'})"/>   
  2. <input id="d4312" class="Wdate" type="text" onFocus="WdatePicker({minDate:'#F{$dp.$D(\'d4311\')}',maxDate:'2020-10-01'})"/>  

前面的日期+3月零2天 不能大于 后面的日期 且 前面日期都不能大于 2020-4-3减去3月零2天 后面日期 不能大于 2020-4-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小时

[javascript]  view plain copy

  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})}'})"/>  
  2. <input type="text" class="Wdate" id="d4332" onFocus="WdatePicker({minDate:'#F{$dp.$D(\'d4331\',{M:3,d:2});}',maxDate:'2020-4-3'})"/>  

无效日期: 禁用每月已5结尾的日期: [javascript]  view plain copy

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

禁用19开头的日期: [javascript]  view plain copy

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

12、日期联动: [javascript]  view plain copy

  1. <input id="d5221" class="Wdate" type="text" onFocus="var d5222=$dp.$('d5222');WdatePicker({onpicked:function(){d5222.focus();},maxDate:'#F{$dp.$D(\'d5222\')}'})"/>  
  2. 至  
  3. <input id="d5222" class="Wdate" type="text" onFocus="WdatePicker({minDate:'#F{$dp.$D(\'d5221\')}'})"/>  

13、onclearing事件取消清空操作 当onclearing返回true时,清空操作取消 [javascript]  view plain copy

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

属性配置

  1. 属性表
    属性 类型 默认值 说明
    静态属性:只能在WdatePicker.js中配置,一般情况下,不建议您修改静态属性的值
    $wdate bool true

    是否自动引入Wdate类 设置为true时,可直接在引入WdatePicker.js的页面里使用 class="Wdate" 

    Wdate可在skin目录下的WdatePicker.css文件中定义

    建议使用默认值

    $dpPath string ''

    是否显示指定程序包的绝对位置,一般情况下为空即可(程序自动创建),该属性是为防止极其少数的情况下程序创建出错而设置的

    设置方法:

    如果,程序包所在http中的地址为 http://localhost/proName/My97DatePicker/

    则 $dpPath = '/proName/My97DatePicker/';

    建议使用默认值

    $crossFrame bool true 是否跨框架,一般设置为true即可,遇到跨域错误时可以将此功能关闭
    可配置属性:可以在WdatePicker方法是配置
    el Element 或 String null 指定一个控件或控件的ID,必须具有value或innerHTML属性(如input,textarea,span,div,p等标签都可以),用户存储日期显示值(也就是dateFmt格式化后的值)
    vel Element 或 String null 指定一个控件或控件的ID,必须具有value属性(如input),用于存储真实值(也就是realDateFmt和realTimeFmt格式化后的值)
    doubleCalendar bool false 是否是双月模式,如果该属性为true,则弹出同时显示2个月的日期框
    enableKeyboard bool true 键盘控制开关
    enableInputMask bool true 文本框输入启用掩码开关
    autoUpdateOnChanged bool null

    在修改年月日时分秒等元素时,自动更新到el,默认是关闭的(即:需要点击确定或点击日期才更新)

    为false时 不自动更新

    为true时 自动更新

    为null时(默认值) 如果有日元素且不隐藏确定按钮时 为false,其他情况为true

    weekMethod string ISO8601

    周算法不同的地方有一些差异

    常见算法有两种

    1. ISO8601:规定第一个星期四为第一周,默认值

    2. MSExcel:1月1日所在的周

    相关链接:http://en.wikipedia.org/wiki/ISO_week_date

    position object {}

    日期选择框显示位置

    注意:坐标单位是px,是相对当前框架坐标(不受滚动条影响),默认情况下系统根据页面大小自动选择

    如:

    {left:100,top:50}表示固定坐标[100,50]

    {top:50}表示横坐标自动生成,纵坐标指定为 50

    {left:100}表示纵坐标自动生成,横坐标指定为 100

    lang string 'auto'

    当值为'auto'时 自动根据客户端浏览器的语言自动选择语言

    当值为 其他 时 从langList中选择对应的语言 

    skin string 'default'

    皮肤名称 默认自带 default和whyGreen两个皮肤

    另外如果你的css够强的话,可以自己做皮肤

    dateFmt string 'yyyy-MM-dd' 日期显示格式
    realDateFmt string 'yyyy-MM-dd'

    计算机可识别的,真正的日期格式

    无效日期设置(disabledDates),最大日期(maxDate),最小日期(minDate)以及快速日期都必须与它们相匹配

    建议使用默认值

    realTimeFmt string 'HH:mm:ss'
    realFullFmt string '%Date %Time'
    minDate string '1900-01-01 00:00:00' 最小日期(注意要与上面的real日期相匹配)
    maxDate string '2099-12-31 23:59:59' 最大日期(注意要与上面的real日期相匹配)
    startDate string ''

    起始日期,既点击日期框时显示的起始日期

    为空时,使用今天作为起始日期(默认值)

    否则使用传入的日期作为起始日期(注意要与上面的real日期相匹配)

    firstDayOfWeek int 周的第一天 0表示星期日 1表示星期一
    isShowWeek bool false 是否显示周
    highLineWeekDay bool true 是否高亮显示 周六 周日
    isShowClear bool true 是否显示清空按钮
    isShowToday bool true 是否显示今天按钮
    isShowOthers bool true 为true时,第一行空白处显示上月的日期,末行空白处显示下月的日期,否则不显示
    readOnly bool false 是否只读
    errDealMode int 纠错模式设置 可设置3中模式 0 - 提示 1 - 自动纠错 2 - 标记
    autoPickDate bool null

    为false时 点日期的时候不自动输入,而是要通过确定才能输入

    为true时 即点击日期即可返回日期值

    为null时(推荐使用) 如果有时间置为false 否则置为true

    qsEnabled bool true 是否启用快速选择功能
    autoShowQS bool false 是否默认显示快速选择
    quickSel Array null

    快速选择数据,可以传入5个快速选择日期

    注意:日期格式必须与 realDateFmt realTimeFmt realFullFmt 相匹配

    disabledDays Array null

    可以使用此功能禁用周日至周六所对应的日期

    0至6 分别代表 周日至周六

    disabledDates Array null 可以使用此功能禁用所指定的一个或多个日期
    opposite bool false

    默认为false, 为true时,无效日期变成有效日期 

    注意:该属性对无效天特殊天不起作用

    specialDates Array null 特殊日期,对指定的日期进行高亮显示
    specialDays Array null

    特殊天,使用此功能禁用周日至周六所对应的日期进行高亮显示

    0至6 分别代表 周日至周六

    onpicking function null 此四个参数为事件参数
    onpicked function null
    onclearing function null
    oncleared function null

    ychanging ychanged 

    Mchanging Mchanged

    dchanging dchanged

    Hchanging Hchanged

    mchanging mchanged

    schanging schanged

    function null

    (4.6Beta3新增)

    y M d H m s 分别表示年月日时分秒

    changing 事件发生在属性改变之前

    changed 事件发生在属性改变之后

内置函数和属性

函数名 返回值类型 作用域 参数 描述
$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格式化后的日期串
$dp.$DV String 全局

v [string]: 日期字符串

arg [object]: 同上例的arg

将传入的日期字符串,加上定义的日期差量,返回使用real格式化后的日期串
以下函数只在事件自定义函数中有效
$dp.cal.getP String 事件function

p [string]: 属性名称 yMdHmswWD分别代表年,月,日,时,分,秒,星期(0-6),周(1-52),星期(一-六) 

f [string]: format 格式字符串

设置方法参考 1.4 自定义格式

返回所指定属性被格式字符串格式化后的值[单属性],在changing,picking,clearing事件中返回选择前的值
$dp.cal.getDateStr String 事件function f [string]: 格式字符串,为空时使用dateFmt 返回所指定属性被格式字符串格式化后的值[整个值],在changing,picking,clearing事件中返回选择前的值
$dp.cal.getNewP String 事件function 用法同$dp.cal.getP 返回所指定属性被格式字符串格式化后的值[单属性],在changing,picking,clearing事件中返回选择后的值
$dp.cal.getNewDateStr String 事件function 用法同$dp.cal.getDateStr 返回所指定属性被格式字符串格式化后的值[整个值],在changing,picking,clearing事件中返回选择后的值
属性名 返回值类型 作用域 参数 描述
$dp.cal.date object 事件function

$dp.cal.date.y:返回 年

$dp.cal.date.M:返回 月

$dp.cal.date.d:返回 日

$dp.cal.date.H:返回 时

$dp.cal.date.m:返回 分

$dp.cal.date.s:返回 秒 

在changing,picking,clearing事件中返回选择前的日期对象
$dp.cal.newdate object 事件function 用法同$dp.cal.date 在changing,picking,clearing事件中返回选择后的日期对象

继续阅读