My97DatePicker 时间控件 整理笔记
来源:广州中睿信息技术有限公司官网
发布时间:2012/10/21 23:25:16 编辑:admin 阅读 788
在开发过程中经常会用户时间控件,但时间控件太多了,下面简单为大家介绍一种:My97DatePicker时间控件虽然网上有现成的方法和MEDO,但由自己总结整理出来,在以后的学习和使用当中会更方便一点

在开发过程中经常会用户时间控件,但时间控件太多了,下面简单为大家介绍一种:My97DatePicker时间控件

虽然网上有现成的方法和MEDO,但由自己总结整理出来,在以后的学习和使用当中会更方便一点儿。

对于My97时间控件,我个人还是比较喜欢的,呵呵。。。

好了,废话不多说,进入主题:

 

(一)My97简介

    1. 当前最新版本: 4.8(还在不断的升级)

    2. 注意事项:(写这个也是为了更多的了解My97)

  • My97DatePicker目录是一个整体,不可破坏里面的目录结构,也不可对里面的文件改名,可以改目录名
  • My97DatePicker.htm是必须文件,不可删除(4.8以后不存在此文件)
  • 各目录及文件的用途:
    WdatePicker.js 配置文件,在调用的地方仅需使用该文件,可多个共存,以xx_WdatePicker.js方式命名
    config.js 语言和皮肤配置文件,无需引入(4.8以后合并入WdatePicker.js)
    calendar.js 日期库主文件,无需引入
    My97DatePicker.htm 临时页面文件,不可删除(4.8以后不存在此文件)
    目录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+   (似乎IE8也应该支持吧)

(二)My97功能

1.常规功能

   1)支持多种调用模式

除了支持常规在input单击或获得焦点调用外,还支持使用其他的元素如:

<img><div>等触发WdatePicker函数来调用弹出日期框(只要传入控件ID)

常规调用:<input id="d11" type="text" onClick="WdatePicker()"/>

图标触发:<input id="d12" type="text"/>

<img onclick="WdatePicker({el:'d12'})" src="../skin/datePicker.gif" width="16" height="22" align="absmiddle">

   2)下拉,输入,导航选择日期

年月时分秒输入框都具备以下三种特性

1. 通过导航图标选择

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

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

   3)支持周显示

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

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

利用onpicked事件把周赋值给另外的文本框:

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

   4)只读开关,高亮周末功能

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

   5)操作按钮自定义

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

禁用清空按钮:<input class="Wdate" type="text" id="d15" onFocus="WdatePicker({isShowClear:false,readOnly:true})"/>

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

   6)  自动选择显示位置 

 

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

   7)  自定义弹出信息

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

通过position属性,自定义弹出位置:<input class="Wdate" type="text" id="d16" onfocus="WdatePicker({position:{left:100,top:50}})"/>

   8)   自定义星期的第一天

各个国家的习惯不同,有些喜欢以星期日作为第一天,有些以星期一作为第一天.
相关属性:firstDayOfWeek: 可设置 0 - 6 的任意一个数字,0:星期日 1:星期一 以此类推

以星期一作为第一天:<input class="Wdate" type="text" id="d17" onfocus="WdatePicker({firstDayOfWeek:1})"/>

2.特色功能

   1)平面显示 

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

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

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

   2)  支持多种容器

除了可以将值返回给input以外,还可以通过配置el属性将值返回给其他的元素(如:textarea,div,span)等,带有innerHTML属性的HTML元素

将日期返回到<span>中:<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" />

   3)  起始日期功能

注意:日期格式必须与 realDateFmt 和 realTimeFmt 一致而不是与 dateFmt 一致

有时在项目中需要选择生日之类的日期,而默认点开始日期都是当前日期,导致年份选择非常麻烦,你可以通过起始日期功能加上配置alwaysUseStartDate属性轻松解决此类问题

1.起始日期简单应用:<input type="text" id="d221" onFocus="WdatePicker({startDate:'1980-05-01'})"/>

   默认的起始日期为 1980-05-01     当日期框为空值时,将使用 1980-05-01 做为起始日期

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

   默认的起始日期为 1980-05-01  当日期框无论是何值,始终使用 1980-05-01 做为起始日期

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

   除了使用静态的日期值以外,还可以使用动态参数(如:%y,%M分别表示当前年和月)
   如:年月日使用当年当月的1日,时分秒使用00:00:00作为起始时间

 

。。。今天先写这么多了,有时间了,再接着写。。。 

 

演示地址:http://my97.gotoip55.com/dp/demo/index.htm

下载地址:http://my97.gotoip55.com/dp/down.asp

联系我们CONTACT 扫一扫
愿景:成为最专业的软件研发服务领航者
中睿信息技术有限公司 广州•深圳 Tel:020-38931912 务实 Pragmatic
广州:广州市天河区翰景路1号金星大厦18层中睿信息 Fax:020-38931912 专业 Professional
深圳:深圳市福田区车公庙有色金属大厦509~510 Tel:0755-25855012 诚信 Integrity
所有权声明:PMI, PMP, Project Management Professional, PMI-ACP, PMI-PBA和PMBOK是项目管理协会(Project Management Institute, Inc.)的注册标志。
版权所有:广州中睿信息技术有限公司 粤ICP备13082838号-2