一. 简介
1. 简介
目前的版本是:4.72
2. 注意事项
- My97DatePicker目录是一个整体,不可破坏里面的目录结构,也不可对里面的文件改名,可以改目录名
- My97DatePicker.htm是必须文件,不可删除
- 各目录及文件的用途: WdatePicker.js 配置文件,在调用的地方仅需使用该文件,可多个共存,以xx_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+ , Chrome, Opera 9.5+ , Safari 3.0+
注意:IE 8.0是完美支持的,如果你在IE8上使用遇到问题,请与我取得联系,务必附上能再现你的问题的纯HTML代码包
三. 配置说明
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 whichDayIsfirstWeek int(1-7之间任何一个数字) 4 周算法不同的地方有一些差异常见算法有三种1. ISO8601:规定第一个星期四为第一周,默认值: 42. MSExcel:1月1日所在的周: 可以填写: 73. 自己根据需要自定义,每年的第一个星期X作为第一周,可以填写: X (X可以是1-7之间任何一个数字)相关链接: position object {} 日期选择框显示位置注意:坐标默认单位是px,是相对当前框架坐标(不受滚动条),left属性只接受数字,top属性除接受数字外还可以接受 'above' 上方显示, 'under' 下方显示, 'auto' 系统根据页面大小自动选择(默认)如:{left:100,top:50}表示固定坐标[100,50]{top:50}表示横坐标自动生成,纵坐标指定为 50{left:100}表示纵坐标自动生成,横坐标指定为 100{top:'above'}表示上方显示{top:'under'}表示下方显示请参考示例 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 是否显示清空按钮 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 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 Mchangeddchanging dchangedHchanging Hchangedmchanging mchangedschanging schanged function null (4.6Beta3新增)y M d H m s 分别表示年月日时分秒changing 事件发生在属性改变之前changed 事件发生在属性改变之后你可以参考 - 配置全局默认值
通过配置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
2. 语言配置
- 语言列表
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 配置语言列表
3. 皮肤配置
- 皮肤列表
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还不是很了解的话一定要多看看这份文档基本上每一个演示的示例下面都有相关代码,并且 关键属性用蓝字标出,关键值用红字标出 应该很容易看明白 如果您有一定的水准希望能从头到尾把功能介绍好好看一遍,这样大部分功能你都会用了如果您是高手建议您通读配置说明和内置函数
五. 内置函数和属性
函数名 | 返回值类型 | 作用域 | 参数 | 描述 |
---|---|---|---|---|
$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 自定义格式 | 返回所指定属性被格式字符串格式化后的值[单属性],在changing,picking,clearing事件中返回选择前的值参考 示例 1-2-2 |
$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事件中返回选择后的日期对象 |
六. 疑难解答
任何问题,请先参考
如果找不到答案,您可以直接在blog留言,或者通过下面的联系方式与我联系七. 联系My97
* 如果您在使用过程中遇到问题,或者有更好的建议
* 欢迎您访问* BLOG: * MAIL: support$my97.net($换成@)* 有问题在我blog留言或给我Email吧,最好先仔细看说明,很多问题都是因为没有仔细看说明导致的