sencha表单里的日期输入框获取日期值进行比较

来源:互联网 发布:淘宝单怎么刷视频教程 编辑:程序博客网 时间:2024/05/16 09:05

sencha 做有自己的输入日期输入框,xtype: 'datepickerfield'。

提交表单后,如果是使用getValue(),那么取到的值是一个日期对象;如果是用getFormattedValue(),取到的值是一个显示区域的格式的值,比如设置有:dateFormat : 'd/m/Y', 那么取到的值也是d/m/Y格式;如果需求要求显示的日期刚好能进行比较,那就还好;如果不一样,方法有两种了:

1、取到格式化的值,然后进行字符串切割,做到可以加减比较来算出天数,不过相差月份转换为天数,也是一个难题,因为有大小月,闰月的说法,这种做法不合理,效果也差;

2、用getValue(),取到对象,然后使用js的日期函数,进行计算:

先取得日期输入框的对象

var date_from = Ext.ComponentQuery.query('datepickerfield')[0];//从上往下,第一个日期输入框var date_to = Ext.ComponentQuery.query('datepickerfield')[1];//第二个日期输入框

(1)比较日期的大小:

Date.parse(date_to.getValue())>=Date.parse(date_from.getValue());//实际是时间戳的对比
(2) 计算日期的相差天数:

var dateMilli = Date.parse(date_to.getValue())-Date.parse(date_from.getValue());//日期减,得到时间戳var count_day = Math.ceil(dateMilli/(24*3600*1000));//时间戳进行除法,转换为天数,然后向上取整,因为1.7,1.5,1.4天也算是两天

原创粉丝点击