extjs 时间范围选择的实现

来源:互联网 发布:淘宝修改销量 编辑:程序博客网 时间:2024/05/02 09:46

extjs中 有时需要选择一个日期范围 ,需要自动判断,选择的开始日期不能大于结束日期,或结束日期不能小于开始日期,实现的代码如下


效果图:


从上图可以看到,当选择了一个开始时间后,会自动限制结束时间的选择范围,实现两个日期选择器的联动.

代码如下:

首先定义联动处理函数:


    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中增加:


        {            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中运行


3 0
原创粉丝点击