extjs 时间范围选择的实现

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

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

时间: 2024-08-06 09:49:15

extjs 时间范围选择的实现的相关文章

日期时间范围选择插件:daterangepicker使用总结

---恢复内容开始--- 分享说明: 项目中要使用日期时间范围选择对数据进行筛选;精确到年月日 时分秒;起初,使用了layui的时间日期选择插件;但是在IIE8第一次点击会报设置格式错误;研究了很久没解决,但能确定不是layui的问题;因为自己写的demo可以在IE8运行;只是在我的项目环境下某些代码冲突了;所以换用了bootstrap插件daterangepicker;看了很多资料;结合官网了文档;基本算是搞定了;把我的总结代码分享给大家;希望对使用daterangepicker插件的初学者有

双日历插件--jq datepicker时间范围选择

<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title></title> <link rel="stylesheet" href="css/jquery-ui.min.css"> <script src="jquery.min.js"&

layui-时间选择器-时间范围选择

HTML: JS: start:就为你选择的开始日期; end:就为你选择的结束日期 此方式可选择任意范围的时间,时间格式可任意修改. 原文地址:https://www.cnblogs.com/wuliMan/p/10488865.html

element-ui的el-date-picker组件(限制时间范围选择)

element-ui的el-date-picker组件有不同的type值能够实现不同的时间选择功能.能够通过pickoption限制选择的范围,但是某些时候我们需要对开始时间和结束时间进行相应的限制, 例如: 某个需求默认起始时间为昨日, 选择时间跨度不可超过366天,在这种情况下有两种解决办法, 1.写两个datepicke组件,把起始时间和结束时间的pickeroptions进行相应的限制,但是这样写的话就需要写较为繁琐的逻辑. 2.写一个datepicker组件,将type设置为dater

开发extjs常用的插件

Spket是目前支持Ext 2.0最为出色的IDE. 它采用.jsb project file 文件并将继承于基类和所有文档的内容嵌入到生成代码提示的Script doc中.注:不支持配置项的代码提示. 一.Spket Eclipse插件与IDE Spket提供了Eclipse插件和独立的IDE环境来支持ExtJs开发,下载地址:http://spket.com/download.html,在下载页面找到如下图所示的地方. Plugin是将Spket直接配置为Eclipse插件进行使用,而Spk

eclipse下安装Extjs的插件spket

最近项目要用ext进行开发,所以这段时间开始学习ext. 我这里用的是ext3.0,eclipse3.5. 每次都要去查API,很烦,所以装个EXT提示的插件对初学者来说有很大的帮助. 假设你已经下载了ext3.0和spket的源码. 注意,官方的ext3.0里面没有提供ext.jsb文件.得自己另外去网上下载一个,这里我把下载到的ext.jsb文件放在ext-3.0.0的根目录下. 一. 以Eclipse插件形式安装 启动ECLIPSE Help → Software Updates → Fi

eclipse+spket+Extjs4.2.1开发环境搭建

鸣谢:http://blog.csdn.net/leimengyuanlian/article/details/18748599 http://www.cnblogs.com/maowang1991/archive/2013/02/05/2893142.html --------------------------------------------------------------------------- 一.下载Extjs4.2.1 http://vzidc.newhua.com/dow

未命名

Extjs 日期选择控件 代码示例: (function(){ Ext.onReady(function(){ Ext.QuickTips.init(); Ext.create('Ext.form.Panel',{ title:'Ext.form.field.Date示例', frame:true, height:300, renderTo:Ext.getBody(), bodyPadding:5, items:[{ fieldLabel:'日期选择框', xtype:'datefield',

VS2015--win32工程配置的一些想法之在 Visual Studio 2015 中进行调试的同时分析性能

出处: https://msdn.microsoft.com/zh-cn/magazine/dn973013(en-us).aspx 许多开发商花了绝大多数时间获取应用程序才能正常发挥作用.更少的时间里专注于应用程序的性能.虽然有了很长一段时间分析工具在 Visual Studio 中的,他们是单独的一组学习工具.许多开发人员没有花时间去学习和使用它们的时候会出现性能问题. 这篇文章将介绍 Visual Studio 2015 年新的诊断工具调试器窗口. 它还将描述如何使用它来分析性能作为定期调