My97 DatePicker使用之自定义事件

参考网站:http://www.my97.net/dp/demo/resource/2.5.asp

    • 自定义事件

      如果你需要做一些附加的操作,你也不必担心,日期控件自带的自定义事件可以满足你的需求.此外,你还可以在自定义事件中调用提供的API库来做更多的运算和扩展,绝对可以通过很少的代码满足你及其个性化的需求.
      注意下面几个重要的指针,将对你的编程带来很多便利 this: 指向文本框 dp: 指向$dp           dp.cal: 指向日期控件对象           注意:函数原型必须使用类似 function(dp){} 的模式,这样子,在函数内部才可以使用dp

    • onpicking 和 onpicked 事件

      示例5-2-1 onpicking事件演示

      <input type="text" id="5421" onFocus="WdatePicker({onpicking:function(dp){if(!confirm(‘日期框原来的值为: ‘+dp.cal.getDateStr()+‘, 要用新选择的值:‘ + dp.cal.getNewDateStr() + ‘覆盖吗?‘)) return true;}})" class="Wdate"/>
      注意:你注意到dp.cal.getDateStr和dp.cal.getNewDateStr的用法了嘛? 详见内置函数和属性

      示例5-2-2 使用onpicked实现日期选择联动

      选择第一个日期的时候,第二个日期选择框自动弹出             日期从:            至            注意:下面第一个控件代码的写法 <input id="d5221" class="Wdate" type="text" onFocus="var d5222=$dp.$(‘d5222‘);WdatePicker({onpicked:function(){d5222.focus();},maxDate:‘#F{$dp.$D(\‘d5222\‘)}‘})"/> 至 <input id="d5222" class="Wdate" type="text" onFocus="WdatePicker({minDate:‘#F{$dp.$D(\‘d5221\‘)}‘})"/>
      注意:$dp.$是一个内置函数,相当于document.getElementById

      示例5-2-3 将选择的值拆分到文本框

      年            月            日            时            分            秒           
                  <input type="text" id="d523_y" size="5"/>            年 <input type="text" id="d523_M" size="3"/>            月 <input type="text" id="d523_d" size="3"/>            日 <input type="text" id="d523_HH" size="3"/>            时 <input type="text" id="d523_mm" size="3"/>            分 <input type="text" id="d523_ss" size="3"/>            秒 <img onclick="WdatePicker({el:‘d523‘,dateFmt:‘yyyy-MM-dd HH:mm:ss‘,onpicked:pickedFunc})" src="../../My97DatePicker/skin/datePicker.gif" width="16" height="22" align="absmiddle" style="cursor:pointer"/> <script> function pickedFunc(){             $dp.$(‘d523_y‘).value=$dp.cal.getP(‘y‘);             $dp.$(‘d523_M‘).value=$dp.cal.getP(‘M‘);             $dp.$(‘d523_d‘).value=$dp.cal.getP(‘d‘);             $dp.$(‘d523_HH‘).value=$dp.cal.getP(‘H‘);             $dp.$(‘d523_mm‘).value=$dp.cal.getP(‘m‘);             $dp.$(‘d523_ss‘).value=$dp.cal.getP(‘s‘);             } </script>
      注意:el:‘d523‘中,如果你不需要d523这个框,你可以把他改成hidden,但是el属性必须指定 $dp.$和$dp.cal.getP都是内置函数

    • onclearing 和 oncleared 事件

      示例5-3-1 使用onclearing事件取消清空操作

      <input type="text" class="Wdate" id="d531" onFocus="WdatePicker({onclearing:function(){if(!confirm(‘日期框的值为:‘+this.value+‘, 确实要清空吗?‘))return true;}})"/>
      注意:当onclearing函数返回true时,系统的清空事件将被取消, 函数体里面没有引用$dp,所以函数原型里面可以省略参数dp

      示例5-3-2 使用cal对象取得当前日期所选择的月份(使用了 dp.cal)

      <input type="text" class="Wdate" id="d532" onFocus="WdatePicker({oncleared:function(dp){alert(‘当前日期所选择的月份为:‘+dp.cal.date.M);}})"/>

      示例5-3-3 综合使用两个事件

      <script> function d533_focus(element){             var clearingFunc = function(){            if(!confirm(‘日期框的值为:‘+this.value+‘, 确实要清空吗?‘)) return true;            }             var clearedFunc = function(){            alert(‘日期框已被清空‘);            } WdatePicker({el:element,onclearing:clearingFunc,oncleared:clearedFunc})             } </script>             <input type="text" class="Wdate" id="d533" onFocus="d533_focus(this)"/>

    • 年月日时分秒的 changing和changed

      年月日时分秒都有对应的changing和changed事件,分别是: ychanging ychanged              Mchanging Mchanged         dchanging dchanged         Hchanging Hchanged         mchanging mchanged         schanging schanged

      示例5-4-1 年月日改变时弹出信息

      <input type="text" class="Wdate" onFocus="WdatePicker({dchanging:cDayFunc, Mchanging:cMonthFunc, ychanging:cYearFunc, dchanged:cDayFunc, Mchanged:cMonthFunc, ychanged:cYearFunc})"/> <script> function cDayFunc(){ cFunc(‘d‘); } function cMonthFunc(){ cFunc(‘M‘); } function cYearFunc(){ cFunc(‘y‘); } function cFunc(who){ var str,p,c = $dp.cal; if(who==‘y‘){ str=‘年份‘; p=‘y‘; } else if(who==‘M‘){ str=‘月份‘; p=‘M‘; } else if(who==‘d‘){ str=‘日期‘; p=‘d‘; } alert(str+‘发生改变了!\n$dp.cal.date.‘+p+‘=‘+c.date[p]+‘\n$dp.cal.newdate.‘+p+‘=‘+c.newdate[p]); } < /script>
      这个例子用到了 $dp.cal.date 和 $dp.cal.newdate 属性,你能从这里发现他们的不同之处吗? 下面是有关这两个属性的描述详见内置函数和属性

      6. 快速选择功能

      此功能允许指定5个最常用的日期,可以方便用户选择,如果不指定,系统将自动生成       相关属性: qsEnabled 是否启用快速选择功能,      注意:如果日期格式里不包含 d(天) 这个元素时,快速选择将一直显示,不收此属性控制 quickSel 快速选择数据,可以传入5个快速选择日期,日期格式同min/maxDate
      注意: 日期格式必须与 realDateFmt  realTimeFmt  相匹配       除了使用静态的日期值以外,还可以使用动态参数(如:%y,%M分别表示当前年和月)

      示例6-1 传入2个静态日期

      <input class="Wdate" type="text" onfocus="WdatePicker({dateFmt:‘yyyy年MM月dd日‘,qsEnabled:true,quickSel:[‘2000-1-10‘,‘2000-2-20‘]})"/>
      注意:当传入的数据不足5个时,系统将自动补全

      示例6-2 传入2个动态日期,1个静态日期

      <input type="text" class="Wdate" onFocus="WdatePicker({dateFmt:‘yyyy年MM月dd日‘,qsEnabled:true,quickSel:[‘2000-10-01‘,‘%y-%M-01‘,‘%y-%M-%ld‘]})"/>
      注意:当传入的数据不足5个时,系统将自动补全

时间: 2024-10-28 02:21:34

My97 DatePicker使用之自定义事件的相关文章

My97 DatePicker普通调用

My97 DatePicker普通调用 1.设计源码 <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>My97

My97 DatePicker图标触发

My97 DatePicker图标触发 1.设计源码 <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>My97

【2016-11-11】【坚持学习】【Day24】【WPF 自定义控件 附加属性 自定义事件】

UserControl ,自定义控件. 这里刚刚想到一个问题.什么时候应该用usercontrol 定义一个控件.什么时候应该重写控件的template和样式,实现新效果. 引用一下人家的话:http://www.cnblogs.com/denghejun/p/3671061.html 我的理解: Usercontrol应该是一个带有功能,带有行为的控件.而一些简单的模型,样式效果,应该都可以用Template实现.它大部分是给呈现效果服务,当然,它可以带有很多事件触发器. 另外,在一些复杂的功

jQuery的自定义事件——滚轮

这个案例类似于在地图上滚动滚轮,能缩小或者放大地图,分别用zoomIn和zoomOut来命名. 代码如下: //JS部分:<script src="jquery-1.10.2.min.js"></script> <script type="text/javascript"> $(function(){ $('img').on('zoomIn', function(){ $(this).css('width', 300) }); $

js中事件(自定义事件)

今天闲的蛋疼,我们来聊一聊web前端中的事件机制和自定义事件.灵感来自jQuery,在此感谢jQuery作者. 首先,最开始. <button id="button" type="button" onclick="alert('hello')">你好</button> 这是我们在使用html写页面的时候最原生的事件触发方式.上面那行代码会生成一个按钮,当我们点击这个按钮的时候就会弹出一个原生的弹窗,内容是hello. 随着

js原生创建模拟事件和自定义事件的方法

让我万万没想到的是,原来<JavaScript高级程序设计(第3版)>里面提到的方法已经是过时的了.后来我查看了MDN,才找到了最新的方法. 1. 模拟鼠标事件 MDN上已经说得很清楚,尽管为了保持向后兼容MouseEvent.initMouseEvent()仍然可用,但是呢,我们应该使用MouseEvent().我们使用如下页面做测试 1 <!DOCTYPE html> 2 <html> 3 <head lang="zh-CN"> 4

javascript和jquey的自定义事件小结

“通过事件机制,可以将类设计为独立的模块,通过事件对外通信,提高了程序的开发效率.” 可以把多个关联但逻辑复杂的操作利用自定义事件的机制灵活地控制好 对象之间通过直接方法调用来交互 1)对象A直接调用对象B的某个方法,实现交互:直接方法调用本质上也是属于一种特殊的发送与接受消息,它把发送消息和接收消息合并为一个动作完成: 方法调用方和被调用方被紧密耦合在一起:因为发送消息和接收消息是在一个动作内完成,所以无法做到消息的异步发送和接收: 2)对象A生成消息->将消息通知给一个事件消息处理器(Obs

js高级技巧----自定义事件

自定义事件 原本的事件处理的原理:事件是javascript与浏览器交互的主要途径. 事件是一种叫做观察者的设计模式 观察者模式由两类对象组成:主体和观察者. 主体用于发布事件: 观察者通过订阅这些事件来观察该主体. 自定义事件的原理: 将事件处理程序保存在一个数组中: 当添加事件的时候,我们push进去这个事件处理函数: 当我们执行的时候,从头遍历这个数组中的每个事件处理函数,并执行. 自定义事件应该具有的内容: 1.一个handler对象,对象中保存着存放事件处理函数的数组 handler 

PB中自定义事件ID含义

PB中自定义事件ID含义 单选或多选按钮消息(前缀:pbm_bm) pbm_bmgetcheck 单选按钮或多选按钮是否被选. pbm_bmgetstate 按钮是否加亮. pbm_bmsetcheck 将无线按钮或确认框的选中状态改为未选中状态,反之亦然. pbm_bmsetstate 加亮或不加亮按钮. pbm_bmchange 改变按钮的风格,例如,改为单选按钮或组合框. 单选或多选按钮通知消息(前缀:pbm_bn) pbm_bnclicked 按钮控件被点中. pbm_bndisable