My97DatePicker日历的平面显示,不是文本框点击事件后显示
二. 功能及示例
2. 特色功能
- 平面显示
日期控件支持平面显示功能,只要设置一下eCont属性就可以把它当作日历来使用了,无需触发条件,直接显示在页面上
示例2-1 平面显示演示
<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元素
示例2-2 将日期返回到<span>中
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 一致而不是与 dateFmt 一致有时在项目中需要选择生日之类的日期,而默认点开始日期都是当前日期,导致年份选择非常麻烦,你可以通过起始日期功能加上配置alwaysUseStartDate属性轻松解决此类问题
示例2-3-1 起始日期简单应用
默认的起始日期为 1980-05-01
当日期框为空值时,将使用 1980-05-01 做为起始日期<input type="text" id="d221" onFocus="WdatePicker({startDate:'1980-05-01'})"/>
示例2-3-2 alwaysUseStartDate属性应用
默认的起始日期为 1980-05-01
当日期框无论是何值,始终使用 1980-05-01 做为起始日期<input type="text" id="d222" onFocus="WdatePicker({startDate:'1980-05-01',alwaysUseStartDate:true})"/>
示例2-3-3 使用内置参数
除了使用静态的日期值以外,还可以使用动态参数(如:%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:ss 2008-03-12 19:20:00 yy年M月 08年3月 yyyyMMdd 20080312 今天是:yyyy年M年d HH时mm分 今天是:2008年3月12日 19时20分 H:m:s 19:20:0 y年 8年 MMMM d, yyyy 三月 12, 2008 示例 2-4-1: 年月日时分秒
<input type="text" id="d241" οnfοcus="WdatePicker({dateFmt:'yyyy年MM月dd日 HH时mm分ss秒'})" class="Wdate" style="width:300px"/>
注意:点两次才能选择日期的原因,详见 autoPickDate 属性
示例 2-4-2 时分秒
<input type="text" id="d242" οnfοcus="WdatePicker({skin:'whyGreen',dateFmt:'H:mm:ss'})" class="Wdate"/>
注意:这里提前使用了皮肤(skin)属性,所以你会看到一个不同的皮肤,皮肤属性详见自定义和动态切换皮肤
示例 2-4-3 年月
<input type="text" id="d243" οnfοcus="WdatePicker({skin:'whyGreen',dateFmt:'yyyy年MM月'})" class="Wdate"/>
示例 2-4-4 取得系统可识别的日期值(重要)
类似于 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格式化后的值)示例 2-4-5 星期, 月 日, 年(4.6新增)
<input type="text" id="d245" οnfοcus="WdatePicker({dateFmt:'DD, MMMM d, yyyy'})" class="Wdate"/>
- 双月日历功能(4.6新增)
可以同时弹出两个月的日历
示例2-5 双月日历功能
<input class="Wdate" type="text" οnfοcus="WdatePicker({doubleCalendar:true,dateFmt:'yyyy-MM-dd'})"/>
注意:双月日历一般只用于包含年月日三个元素的场景,另外设置该属性时,autoPickDate自动设置为true
- 自动纠错功能
纠错处理可设置为3种模式:提示(默认) 自动纠错 标记,当日期框中的值不符合格式时,系统会尝试自动修复,如果修复失败会根据您设置的纠错处理模式进行处理,错误判断功能非常智能它可以保证用户输入的值是一个合法的值
示例2-6-1 不合法的日期演示
请在下面的日期框中填入一个不合法的日期(如:1997-02-29),再尝试离开焦点
使用默认容错模式 提示模式 errDealMode = 0 在输入错误日期时,会先提示注意:1997年不是闰年哦
示例2-6-2 超出日期限制范围的日期也被认为是一个不合法的日期
最大日期是2000-01-10 ,如果在下框中填入的日期 大于 2000-01-10(如2000-01-12)也会被认为是不合法的日期
自动纠错模式 errDealMode = 1 在输入错误日期时,自动恢复前一次正确的值示例2-6-3 使用无效天和无效日期功能限制的日期也被认为是一个不合法的日期
如:
2008-02-20 无效日期限制
2008-02-02 2008-02-09 2008-02-16 2008-02-23 无效天限制
都是无效日期
您可以尝试在下框中输入这些日期,并离开焦点标记模式 errDealMode = 2 在输入错误日期时,不做提示和更改,只是做一个标记,但此时日期框不会马上隐藏
注意:标记类:WdateFmtErr是在skin目录下WdatePicker.css中定义的
- 跨无限级框架显示
无论你把日期控件放在哪里,你都不需要担心会被外层的iframe所遮挡进而影响客户体验,因为My97日期控件是可以跨无限级框架显示的
示例2-7 跨无限级框架演示
可无限跨越框架iframe,无论怎么嵌套框架都不必担心了,即使有滚动条也不怕
注意:Javascript是无法跨越frameset的,但是My97日期控件可无限跨越框架iframe,任何的frameset都可以使用iframe代替 - 民国年日历和其他特殊日历
当年份格式设置为yyy格式时,利用年份差量属性yearOffset(默认值1911民国元年),可实现民国年日历和其他特殊日历
示例2-8 民国年演示
<input type="text" id="d28" onClick="WdatePicker({dateFmt:'yyy/MM/dd'})"/>
注意:年份格式设置成yyy时,真正的日期将会减去一个差量yearOffset(默认值为:1911),如果是民国年使用默认值即可无需另外配置,如果是其他的差量,可以通过参数的形式配置
- 编辑功能
当日期框里面有值时,修改完某个属性后,只要点击这个按钮就可以实现时间和日期的编辑
示例2-9 日期和时间的编辑演示
您可以尝试对下面框中的月份改为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"就会在选择框右边出现日期图标
3. 多语言和自定义皮肤
4. 日期范围限制
5. 自定义事件
6. 快速选择功能
三. 配置说明
四. 如何使用
转载于:https://www.cnblogs.com/Jhon-xu/p/4466083.html
My97DatePicker日历的平面显示,不是文本框点击事件后显示相关推荐
- iOS 9应用开发教程之显示编辑文本标签文本框
iOS 9应用开发教程之显示编辑文本标签文本框 ios9显示.编辑文本 在iOS,经常会看到一些文本的显示.文字就是这些不会说话的设备的嘴巴.通过这些文字,可以很清楚的指定这些设备要表达的信息.本节将 ...
- java复选框如何显示在文本雨_java – 在复选框的itemStatechanged事件上显示文本字段...
如何在Swing中的复选框的itemStatechanged事件中显示文本字段? 我正在尝试使用复选框和文本字段创建框架.我希望仅在选中复选框时才显示文本字段.因此,当我初始化组件时,我将textfi ...
- 泛微OA 子表单中文本框设置默认值不显示的问题
2021年5月18日 截止以上日期,子表单可能存在bug,解决方式: 这个不显示默认值的文本框(比如叫默认值文本框),必须设置显示条件: 1.如果没有条件,创造一个:在任意位置添加一个文本框(用户ID ...
- css实现文本框中内容超出长度显示省略号,鼠标移入悬浮显示全部内容
css样式: width: 300px;text-overflow: ellipsis;overflow: hidden; 此时的设置可以完美实现文本框中的内容超长显示为省略号:但是想知道全部内容是不 ...
- fastadmin 简单的根据单选按钮显示对应的文本框
fastadmin 简单的根据单选按钮显示对应的文本框 效果介绍:在点击添加修改时,对于一些字段只是在某种情况下才会出现 效果如图 ,其实实现很简单,只需要JQ就好 <div class=&qu ...
- 电脑桌面图标右下角显示有白色文本框
电脑桌面图标右下角显示有白色文本框 #1.尝试过加入脚本.bat 失败 @echo off taskkill /f /im explorer.exe CD /d %userprofile%\AppDa ...
- jsp页面input框如何监控数据变化_jsp页面文本框监听事件,该如何解决
jsp页面文本框监听事件 在火狐浏览器下用什么事件可以监听文本框类值的改变,该值不一定要输入,比如通过日历控件改变文本框的值也可以监听到.求高手解答啊 ------解决思路-------------- ...
- tableView cell 中如果有文本框点击自动滚动不被键盘挡住
tableView cell 中如果有文本框点击自动滚动不被键盘挡住 tableView 是继承UIscrollView,所以自然有setContentOffset方法,该方法可以设置tableVie ...
- 富文本带点击事件的解决方案
富文本带点击事件的解决方案 效果 分析 富文本中要添加点击link事件,需要深入到CoreText里面才能够解决,本人将TTTAttributedLabel进行了封装(封装并不完全,以后会继续完善), ...
最新文章
- iOS架构设计-URL缓存(上)
- 在Linux下配置TCP/IP
- JAVA程序员必看的15本书
- 西双版纳真的适合养老吗?
- 重磅!阿里推出国产开源的JDK!这是要干掉oracle??
- 网易公开课与网易云课堂的区别
- 【纯干货】SpringBoot 整合 ES 进行各种高级查询搜索
- Linux线程同步(三)---互斥锁源码分析
- python两个csv表数据合并_python – 根据列中的数据合并两个CSV文件
- 苹果开发者账号申请 App IDs(应用身份证)
- 小白MacBook超级实战教程——装双系统WIN10
- iar使用:创建工程
- android pixel 2,谷歌 Pixel 2 评测:目前最好的安卓手机
- 魔乐科技安卓开发教程----李兴华----08APPWidget
- 跨平台开发解决方案有哪些?
- Abaqus过盈配合接触案例
- 《可复制的领导力》思维导图
- 学计算机心得体会50字,心得体会50字
- 温老师的论坛,欢迎大家踊跃发言!
- -g、-ggdb、-g3和-ggdb3之间的区别
热门文章
- leetcode - 96. 不同的二叉搜索树
- TensorFlow第十二步 自编码器去噪降维
- 以太网接口MII,RMII,SMII,GMII总线接口简介
- 椭圆极点极线性质_笔记:关于极点极线的一些思考
- fifo算法模拟_我是怎样学习算法的?(V1.0)
- java 监听事件和处理事件_Java基础教程之事件和监听器
- qcalendarwidget只显示月_万家基金旗下26只产品规模迷你 万家精选重仓地产股年内收益排名靠后丨基金...
- phoenix的元数据一般存在哪里_ElasticSearch文档元数据(Metadata)
- .net 链oracle,.net链数据库oracle
- php 读写远程文件内容,php获取远程文件内容的函数