WdatePicker日历控件使用方法

一.介绍:

日期控件,使用需引入WdatePicker.js文件

支持的浏览器

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

二.功能实例

http://www.my97.net/dp/demo/resource/2.1.asp


三.配置说明

1. 属性配置

  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周的第一天 0表示星期日 1表示星期一
    isShowWeek bool false是否显示周
    你可以参考周显示示例
    highLineWeekDay bool true是否高亮显示 周六 周日
    isShowClear bool true是否显示清空按钮
    isShowOK bool true是否显示确定按钮
    isShowToday bool true是否显示今天按钮
    isShowOthers bool true为true时,第一行空白处显示上月的日期,末行空白处显示下月的日期,否则不显示
    readOnly bool false是否只读
    errDealMode int 0纠错模式设置 可设置3中模式 0 - 提示 1 - 自动纠错 2 - 标记
    autoPickDate bool null为false时 点日期的时候不自动输入,而是要通过确定才能输入
    为true时 即点击日期即可返回日期值
    为null时(推荐使用) 如果有时间置为false 否则置为true
    hmsMenuCfg Object { H: [1, 6], m: [5, 6], s: [15, 4] }

    4.8beta4新增

     

    使用hmsMenuCfg属性可以实现时分秒菜单的自定义
    时分秒自定义 H m s 分别代表时分秒
    第一个参数表示步进,1表示0,1,2,3... 2表示0,2,4... 15表示0,15,30...
    第二个参数表示每行显示值的数量
    默认H [1, 6] 步进1 每行显示6个 共4行
    默认m [5, 6] 步进5 每行显示6个 共2行
    默认s [15, 4] 步进15 每行显示4个 共1行

    qsEnabled bool true

    是否启用快速选择功能

    注意:当日期格式中没有d这个元素时(如yyyy-MM或HH:mm:ss这样的格式时),该属性永远为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 nully M d H m s 分别表示年月日时分秒
    changing 事件发生在属性改变之前
    changed 事件发生在属性改变之后

    你可以参考示例5-4-1
  2. 配置全局默认值

    通过配置WdatePicker.js的属性可以避免每次调用都传入配置值,为变成带来很多方便.
    在默认情况下My97为每个属性都配置了默认值,这些默认值都可以在WdatePicker.js中修改的
    你可以根据你个人的喜好更改这些值

    比如你比较不喜欢默认的皮肤default 而更喜欢 whyGreen 这个皮肤,
    你可以直接在WdatePicker.js把skin值改为 whyGreen
    这样,你就不必每次调用控件的时候都传入 skin:'whyGreen' 了
    你学会了吗?

  3. 配置单个控件

    在控件里面你可以使用 onfocus 或 onclick 事件来调用WdatePicker函数来触发日期控件
    WdatePicker({})其中{}中的内容都是只对当前实例有效,你可以任意配置属性表里有的所有属性
    你可以随意的组合这些属性,达到你的需求
    My97日期控件在这方面是做得非常灵活的.

  4. 多套配置快速切换

    您可以设置多个WdatePicker.js文件,如 cn_WdatePicker.js,en_WdatePicker.js,simple_WdatePicker.js等
    在不同的页面引入不同的 WdatePicker.js 达到配置快速切换的目的.
    注意:文件必须以 _WdatePicker.js(大小写不限制) 为后缀,形如 <yourname>_WdatePicker.js

2. 语言配置

  1. 语言列表

    My97DatePicker目录下有个config.js(4.8以后在WdatePicker.js中),里面有段代码: 
    var langList = 
    [
    {name:'en',charset:'UTF-8'},
    {name:'zh-cn', charset:'gb2312'},
    {name:'zh-tw', charset:'GBK'}
    ];

    这就是语言列表,每个项有name和charset两个属性.
    name 表示语言的名称(必须与浏览器的语言字符串命名相同),在配置的时候,lang属性只能是配置列表里面已有的项,否则将自动返回第一项
    charset 表示对应语言目录下的js文件所对应的编码格式

  2. 语言安装说明

    分两步轻松实现:
    1 将语言文件拷贝到 lang 目录
    2 打开 config.js 配置语言列表

3. 皮肤配置

  1. 皮肤列表

    My97DatePicker目录下有个config.js(4.8以后在WdatePicker.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所对应的编码格式

  2. 皮肤安装说明

    分两步轻松实现:
    1 将皮肤文件包拷贝到 skin 目录
    2 打开 config.js 配置皮肤列表 

四.如何使用

1. 在使用该日期控件的文件中加入JS库(仅这一个文件即可,其他文件会自动引入,请勿删除或改名), 代码如下 <script language="javascript" type="text/javascript" src="datepicker/WdatePicker.js"></script>
注:src="datepicker/WdatePicker.js" 请根据你的实际情况改变路径

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

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

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

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


五. 内置函数和属性

函数名 返回值类型 作用域 参数 描述
$dp.show void 全局显示日期选择框
$dp.hide void 全局隐藏日期选择框
$dp.unbind
(4.8beta4新增)
void 全局el [string/object]:取消绑定的对象,可传入dom对象或者是对象的ID让传入的对象取消日期控件绑定
$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 事件functionp [string]: 属性名称 yMdHmswWD分别代表年,月,日,时,分,秒,星期(0-6),周(1-52),星期(一-六) 
f [string]: format 格式字符串
设置方法参考 1.4 自定义格式
返回所指定属性被格式字符串格式化后的值[单属性],在changing,picking,clearing事件中返回选择前的值
参考 示例 1-2-2
$dp.cal.getDateStr String 事件functionf [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事件中返回选择后的日期对象



原文:http://www.cnblogs.com/yuhanzhong/archive/2011/08/10/2133276.html

1. 跨无限级框架显示

 

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

 

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

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

 

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

 

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

示例2-8 民国年演示


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

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

 

3. 编程带来方便

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

 

4. 其他属性

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

 

 

多语言和自定义皮肤

1. 多语言支持

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

示例3-1 多语言示例

繁体中文:
<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',即根据浏览器的语言自动选择语言.

 

2. 自定义和动态切换皮肤

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

 

示例3-2 皮肤演示

默认皮肤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'})"/>

 

 

4. 日期范围限制

1. 静态限制
注意:日期格式必须与realDateFmtrealTimeFmt一致

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

示例4-1-1 限制日期的范围是 2006-09-10到2008-12-20
<input id="d411" class="Wdate" type="text" οnfοcus="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" 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"/>

 

示例4-1-3 限制日期的范围是 2008年2月 到 2008年10月
<input type="text" class="Wdate" id="d413" οnfοcus="WdatePicker({dateFmt:'yyyyM',minDate:'2008-2',maxDate:'2008-10'})"/>

 

示例4-1-4 限制日期的范围是 8:00:00 到 11:30:00
<input type="text" class="Wdate" id="d414" οnfοcus="WdatePicker({dateFmt:'H:mm:ss',minDate:'8:00:00',maxDate:'11:30:00'})"/>

 

2. 动态限制
注意:日期格式必须与realDateFmtrealTimeFmt一致

你可以通过系统给出的动态变量,%y(当前年),%M(当前月)等来限度日期范围,

还可以通过#{}进行表达式运算,:#{%d+1}:表示明天

动态变量表

格式

说明

%y

当前年

%M

当前月

%d

当前日

%ld

本月最后一天

%H

当前时

%m

当前分

%s

当前秒

#{}

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

#F{}

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

 

示例4-2-1 只能选择今天以前的日期(包括今天)
<input id="d421" class="Wdate" type="text" οnfοcus="WdatePicker({skin:'whyGreen',maxDate:'%y-%M-%d'})"/>

 

示例4-2-2 使用了运算表达式只能选择今天以后的日期(不包括今天)
<input id="d422" class="Wdate" type="text" οnfοcus="WdatePicker({minDate:'%y-%M-#{%d+1}'})"/>

 

示例4-2-3 只能选择本月的日期1号至本月最后一天
<input id="d423" class="Wdate" type="text" οnfοcus="WdatePicker({minDate:'%y-%M-01',maxDate:'%y-%M-%ld'})"/>

 

示例4-2-4 只能选择今天7:00:00至明天21:00:00的日期
<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'})"/>

 

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


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

 

3 . 脚本自定义限制
      
注意:日期格式必须与realDateFmtrealTimeFmt一致

 

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

 

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

合同有效期从  
<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.getElementById 函数.
那么为什么里面的
' 使用\'?那是因为" ' 都被外围的函数使用了,故使用转义符\ ,否则会提示JS语法错误.
所以您在其他地方使用时注意把
\' 改成"或者 ' 来使用.

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

 

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

       日期从 
      
<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分别代表年月日时分秒


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值