html5中文学习网

您的位置: 首页 > 网站及特效实例 > javascript特效 » 正文

extjs 时间范围选择自动判断的实现代码_extjs_

[ ] 已经帮助:人解决问题

extjs中 有时需要选择一个日期范围,需要自动判断,选择的开始日期不能大于结束日期,或结束日期不能小于开始日期,实现的代码如下scdHTML5中文学习网 - HTML5先行者学习网

效果图:scdHTML5中文学习网 - HTML5先行者学习网
scdHTML5中文学习网 - HTML5先行者学习网
从上图可以看到,当选择了一个开始时间后,会自动限制结束时间的选择范围,实现两个日期选择器的联动.scdHTML5中文学习网 - HTML5先行者学习网

代码如下:scdHTML5中文学习网 - HTML5先行者学习网

首先定义联动处理函数:scdHTML5中文学习网 - HTML5先行者学习网
scdHTML5中文学习网 - HTML5先行者学习网

Ext.apply(Ext.form.field.VTypes, { daterange: function (val, field) { var date = field.parseDate(val); if (!date) { return false; } if (field.startDateField && (!this.dateRangeMax || (date.getTime() != this.dateRangeMax.getTime()))) { var start = field.up('grid').down('#' + field.startDateField); start.setMaxValue(date); start.validate(); this.dateRangeMax = date; } else if (field.endDateField && (!this.dateRangeMin || (date.getTime() != this.dateRangeMin.getTime()))) { var end = field.up('grid').down('#' + field.endDateField); end.setMinValue(date); end.validate(); this.dateRangeMin = date; } return true; }, daterangeText: '开始日期必须小于结束日期' }); Ext.tip.QuickTipManager.init();

在tbar,bbar或form中的items中增加:scdHTML5中文学习网 - HTML5先行者学习网
scdHTML5中文学习网 - HTML5先行者学习网

{ xtype: 'datefield', fieldLabel: '时间范围 开始', name: 'startdt', id: 'startdt', vtype: 'daterange', endDateField: 'enddt', format: 'Y-m-d', width: 220, labelWidth: 90, msgTarget: 'side', autoFitErrors: false }, { xtype: 'datefield', fieldLabel: '结束', name: 'enddt', id: 'enddt', vtype: 'daterange', startDateField: 'startdt', format: 'Y-m-d', width: 170, labelWidth: 40, msgTarget: 'side', autoFitErrors: false }, { xtype: 'button', text: '查询', iconCls: 'fljs', handler: function () { ...

即可实现以上效果 本代码复制在extjs4.1.1中运行scdHTML5中文学习网 - HTML5先行者学习网

(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助