首页 > Web开发 > 详细

extjs 时间范围选择的实现

时间:2014-06-24 15:59:17      阅读:438      评论:0      收藏:0      [点我收藏+]

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


效果图:

bubuko.com,布布扣


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

代码如下:

首先定义联动处理函数:


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


extjs 时间范围选择的实现,布布扣,bubuko.com

extjs 时间范围选择的实现

原文:http://blog.csdn.net/olinbsoft/article/details/34087503

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!