博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ux.form.field.GridDate 支持快速选择日期的日期控件
阅读量:6647 次
发布时间:2019-06-25

本文共 4732 字,大约阅读时间需要 15 分钟。

效果如图,亲测6.2.1版本可用

1 /** 2  *支持快速选择日期的日期控件 3  */ 4 Ext.define('ux.form.field.GridDate', { 5     extend: 'Ext.form.field.Date', 6     alias: 'widget.gridDateField', 7     requires: ['ux.picker.GridDate'], 8     pickerGrid: { 9         store: {10             //默认配置11             data: [{12                 value: 30,13                 text: '一个月后'14             },15             {16                 value: 90,17                 text: '三个月后'18             },19             {20                 value: 180,21                 text: '六个月后'22             },23             {24                 value: 365,25                 text: '一年后'26             },27             {28                 value: 365 * 2,29                 text: '两年后后'30             },31             {32                 value: 365 * 3,33                 text: '三年后'34             }]35         }36     },37     //创建弹窗38     createPicker: function () {39         var me = this,40         format = Ext.String.format;41         return new ux.picker.GridDate({42             floating: true,43             hidden: true,44             pickerField: me,45             pickerGrid: me.pickerGrid,46             pickerDate: {47                 pickerField: me,48                 focusable: false,49                 // Key events are listened from the input field which is never blurred50                 preventRefocus: true,51                 minDate: me.minValue,52                 maxDate: me.maxValue,53                 disabledDatesRE: me.disabledDatesRE,54                 disabledDatesText: me.disabledDatesText,55                 ariaDisabledDatesText: me.ariaDisabledDatesText,56                 disabledDays: me.disabledDays,57                 disabledDaysText: me.disabledDaysText,58                 ariaDisabledDaysText: me.ariaDisabledDaysText,59                 format: me.format,60                 showToday: me.showToday,61                 startDay: me.startDay,62                 minText: format(me.minText, me.formatDate(me.minValue)),63                 ariaMinText: format(me.ariaMinText, me.formatDate(me.minValue, me.ariaFormat)),64                 maxText: format(me.maxText, me.formatDate(me.maxValue)),65                 ariaMaxText: format(me.ariaMaxText, me.formatDate(me.maxValue, me.ariaFormat)),66                 listeners: {67                     scope: me,68                     select: me.onSelect,69                     tabout: me.onTabOut70                 },71                 keyNavConfig: {72                     esc: function () {73                         me.inputEl.focus();74                         me.collapse();75                     }76                 }77             }78         });79     }80 });
1 /** 2  * 支持快速选择日期的日期控件 3  */ 4 Ext.define('ux.picker.GridDate', { 5     extend: 'Ext.container.Container', 6     alias: 'widget.gridDatePicker', 7     requires: ['Ext.picker.Date', 'Ext.form.field.ComboBox'], 8     layout: 'hbox', 9     config: {10         pickerDate: {11 12         },13         pickerGrid: {14             width: 120,15             height:'100%',16             title: '快速选择',17             hideHeaders: true,18             columns: [{19                 flex:1,20                 dataIndex: 'text'21             }]22         }23     },24     //初始化25     initComponent: function () {26         var me = this;27         me.callParent(arguments);28         me.add([me.getPickerGrid(), me.getPickerDate()]);29     },30     //创建时间控件31     applyPickerDate: function (config) {32         return Ext.factory(config, 'Ext.picker.Date', this.getPickerDate());33     },34     //创建下拉框35     applyPickerGrid: function (config) {36         return Ext.factory(config, 'Ext.grid.Panel', this.getPickerGrid());37     },38     //更新下拉框39     updatePickerGrid: function (item) {40         if (item) {41             item.on({42                 itemclick: 'onItemclick',43                 scope: this44             });45         }46     },47     //快速选择48     onItemclick: function (t, rec) {49         //设置值50         this.pickerField.setValue(new Date(Date.now() + 1000 * 60 * 60 * 24 * rec.get('value')));51         //隐藏弹出层52         this.pickerField.collapse();53     },54     //设置禁止时间55     setDisabledDates: function (value) {56         this.getPickerDate().setDisabledDates(value);57     },58     //设置禁止日期59     setDisabledDays: function (value) {60         this.getPickerDate().setDisabledDays(value);61     },62     //设置最小值63     setMinValue: function (value) {64         this.getPickerDate().setMinDate(value);65     },66     //设置最大值67     setMaxValue: function (value) {68         this.getPickerDate().setMaxDate(value);69     },70     //设置值71     setValue:function (value) {72         this.getPickerDate().setValue(value);73     }74 });

 

转载地址:http://houto.baihongyu.com/

你可能感兴趣的文章
Android InputStreamReader 解析gbk、gb2312编码的xml文件 编码问题.
查看>>
记录安装oracle的那些事(二)之双系统安装
查看>>
ssh服务器配置方法
查看>>
Django安装配置
查看>>
bootstrap源码学习与示例:bootstrap-tab
查看>>
[C] 让VC支持C99的整数类型V1.01。避免包含目录问题,更名auto_stdint.h、auto_inttypes.h(在VC6至VC2012、GCC、BCB等编译器下测试通过)...
查看>>
Apache OFBiz 10.04.05 发布,安全漏洞修复
查看>>
京东书4
查看>>
Java EE之RMI
查看>>
ASCII编码表 -- SQL注入 也需要
查看>>
MySQL常用数据类型介绍
查看>>
当装系统时遇到“选中的磁盘采用GPT分区形式”
查看>>
CentOS的远程桌面(xdm)
查看>>
Some aspects to prepare
查看>>
oracle 好书 05 ( 内存组件与 oracle 进程 )
查看>>
Linux gdb符号调试器
查看>>
http_load
查看>>
metasploit tutorial
查看>>
安装 iis 的方式
查看>>
Spring MVC 拦截器问题,如何配置不需要拦截的页面
查看>>