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