EXTJS项目实战经验总结一:日期组件的change事件:
1 依据选择的日期,加载相应的列表数据,如图:
开发说明
1 开发思路: 在日期值变化的事件中获得选择后的日期值,传给后台,然后从后台加载相应的数据
2 问题:在查看extjs2.2 的api的官方说明文档,文档对datefield组件的change事件说明如下:
change : ( Ext.form.Field this, Mixed newValue, Mixed oldValue )
Fires just before the field blurs if the field value has changed.
这句话是说值发生变化,并且在失去焦点之前触发此事件,也就是说如果此日期组件的值发生变化,而焦点并没有失去,这个事件也就不会触发。通过我们的程序验证,事实也的确如此。我们需要值发生变化就要触发相应的事件。
3 解决方法:
从源头找事件:是用户点击相应的日期,才导致文本框里的值发生变换。可以捕获这个点击选择事件,通过这个事件我们得到日期值,传给后台,加载列表数据
4 具体做法:
继承Ext.form.DateField,覆盖menuListeners这个私有监听器属性,封装类如下:
- Ext.form.CustomDateField = Ext.extend(Ext.form.DateField, {
- // private
- readOnly: true,
- setValueFn:null,
- menuListeners : {
- select: function(m, d){
- this.setValue(d);
- if(this.setValueFn)
- this.setValueFn.call(this,this.formatDate(this.parseDate(d)));
- },
- show : function(){
- this.onFocus();
- },
- hide : function(){
- this.focus.defer(10, this);
- var ml = this.menuListeners;
- this.menu.un("select", ml.select, this);
- this.menu.un("show", ml.show, this);
- this.menu.un("hide", ml.hide, this);
- }
- }
- });
- Ext.reg('customDateField', Ext.form.CustomDateField);
- Ext.form.CustomDateField = Ext.extend(Ext.form.DateField, {
- // private
- readOnly: true,
- setValueFn:null,
- menuListeners : {
- select: function(m, d){
- this.setValue(d);
- if(this.setValueFn)
- this.setValueFn.call(this,this.formatDate(this.parseDate(d)));
- },
- show : function(){
- this.onFocus();
- },
- hide : function(){
- this.focus.defer(10, this);
- var ml = this.menuListeners;
- this.menu.un("select", ml.select, this);
- this.menu.un("show", ml.show, this);
- this.menu.un("hide", ml.hide, this);
- }
- }
- });
- Ext.reg('customDateField', Ext.form.CustomDateField);
5 使用这个自定义的组件:
例:
- {
- fieldLabel : '计划开始日期',
- vtype : 'isBlank',
- xtype : 'datefield',
- xtype : 'customDateField',
- setValueFn:function(value){
- alert(value);
- },
- format : 'Y-m-d'
- }
- {
- fieldLabel : '计划开始日期',
- vtype : 'isBlank',
- xtype : 'datefield',
- xtype : 'customDateField',
- setValueFn:function(value){
- alert(value);
- },
- format : 'Y-m-d'
- }
这种方法不好的地方,就是覆盖了extjs提供的私有属性menuListeners,不知路过的朋友,有没有比较好的解决办法
分类:
前台ExtJs
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】
2012-06-30 一种最好用的php生成excel的代码 适用于windows和linux
2012-06-30 终于搞定PHP连接SQLServer2005(用这个)
2012-06-30 php.ini-dist 与php.ini-recommended
2011-06-30 服务端解析json格式