Ant Design 日期选择组件RangePicker 选择时间范围后计算范围内的天数。
/**
*需求:同年同月,同年不同月(两个月相减大于1,小于1),不同年(两个年相减大于1(是否为闰年),小于1),起止包含的月份及天
*/
//首先引入组件
import { DatePicker} from 'antd';
const { RangePicker } = DatePicker; //render中引入 <RangePicker style={{marginRight: 15}}
format="YYYY-MM-DD"
onChange={this.filterByDayRange}
/>
//接下来是功能函数
//计算开始天数差
getStartEnd = (year, month, date) => {
let number = 0;
let start_day = parseInt(date);
let end_day = parseInt(getMonthEndDate(year,month-1).split('-')[2]);
return Math.abs(parseInt(end_day) - parseInt(start_day) + 1)
} // 判断某一年是平年还是闰年
isLeapYear = (year) => {
let number = 0;
((year%4==0) && (year%100!=0)) || (year%400==0) ? number = 366 : number = 365;
// console.log(number)
return number;
} //获取当两个年份差为1的天数
getBetweenYears = (_year1,_year2,month1,month2,date1,date2) => {
// 第一个日期
let monthRange1 = [];
let month1_mun1 = 0;
let other_num1 = 0; let len1 = 12 - parseInt(month1);
if(len1 > 0){//若果月份之差大于0
for(var j = 1; j <= len1; j ++){
let _m1 = getMonthEndDate(_year1,Math.abs((parseInt(month1)+j) - 1)).split('-')[2]; monthRange1.push(parseInt(_m1))
}
other_num1 = monthRange1.reduce((sum,item) =>{//前面其他部分
return sum + item;
},0);
month1_mun1 = this.getStartEnd(_year1,month1,date1);//前面第一部分 }else{//如果当前月为12月
month1_mun1 = this.getStartEnd(_year1,month1,date1);//前面第一部分
}
// 第二个日期
let monthRange2 = [];
let month2_mun1 = 0;
let other_num2 = 0; let len2 = parseInt(month2) - 1;
if(len2 > 0){//若果月份之差大于0
for(var k = 1; k <= len2;k ++){
let _m2 = getMonthEndDate(_year2,Math.abs((parseInt(month2)-k) - 1)).split('-')[2]; monthRange2.push(parseInt(_m2))
}
other_num2 = monthRange2.reduce((sum,item) =>{//前面其他部分
return sum + item;
},0);
month2_mun1 = parseInt(date2);//前面第一部分 }else{//如果当前月为1月
month2_mun1 = parseInt(date2);//前面第一部分
}
return parseInt(month1_mun1) + parseInt(other_num1) + parseInt(month2_mun1) + parseInt(other_num2);
} //计算天数(判断平年,闰年的天数)
getDayNum = (day1, day2) => {
let _num;//天数
// console.log(day1, day2)
let startArr = day1.split('-'),
endArr = day2.split('-'),
_year1 = startArr[0],
_year2 = endArr[0],
month1 = startArr[1],
month2 = endArr[1],
date1 = startArr[2],
date2 = endArr[2]; if(_year1 == _year2){//同一年
if(month1 == month2){//同年同月
// console.log(month1)
_num = Math.abs(parseInt(startArr[2]) - parseInt(endArr[2])) + 1;
// console.log("同年同月",_num)
}else{//同年不同月
//计算month1和month2之间的月份
let monthRange = [];
let len = parseInt(month2) - parseInt(month1);
// console.log(len)
if(len > 1){//如果两个月相减大于1,统计中间的月份
for(var i = 1; i < len; i++){
let _m = getMonthEndDate(_year1,Math.abs((parseInt(month1)+i) - 1)).split('-')[2]; monthRange.push(parseInt(_m))
}
let other_num = monthRange.reduce((sum,item) =>{
return sum + item;
},0);
let month1_mun = this.getStartEnd(_year1,month1,date1);
let month2_mun = parseInt(date2);
_num = parseInt(month1_mun) + parseInt(month2_mun) + parseInt(other_num);
// console.log("同年不同月且月份相差大于1",_num) }else{//如果两个月相减为1
let month1_mun = this.getStartEnd(_year1,month1,date1);
let month2_mun = parseInt(date2);
_num = parseInt(month1_mun) + parseInt(month2_mun);
// console.log("同年不同月且月份相差等于1",_num)
}
}
}else{//不是同一年
let yearRange = [];
let other_year_num = 0;
let _len = _year2 - _year1;
if(_len > 1){
for(var h = 1; h < _len; h++){
let _y = parseInt(_year1 + h); yearRange.push(this.isLeapYear(_y))
} other_year_num = yearRange.reduce((sum,item) =>{
return sum + item;
},0); let other_month_num = this.getBetweenYears(_year1,_year2,month1,month2,date1,date2); _num = parseInt(other_year_num) + parseInt(other_month_num); // console.log("不同年且年份相减大于1",_num)
}else{ _num = this.getBetweenYears(_year1,_year2,month1,month2,date1,date2); // console.log("不同年且年份相减等于1",_num)
} } return _num;
} //根据时间范围filterByDayRange
filterByDayRange = (value,dateString) => {
// console.log(dateString)
if(dateString[0] != ''){
let _num = this.getDayNum(dateString[0], dateString[1]); let _startTime = dateString[0] + ' 00:00:00';;
let _endTime = dateString[1] + ' 23:59:59'; this.setState({
startTime: _startTime,
endTime: _endTime,
num: _num,
current: 1
}, () => {
this.fetch(this.state.current, this.state.pageSize,this.getParamsObj());
})
}else{
let start_end = this.getCurrentMonth();
this.setState({
startTime:start_end.start,
endTime:start_end.end,
current:1
}, () => {
this.fetch(this.state.current, this.state.pageSize,this.getParamsObj());
})
}
}
Ant Design 日期选择组件RangePicker 选择时间范围后计算范围内的天数。的更多相关文章
- 封装一个漂亮的ant design form标签组件
在ant design 的form组件中 能用于提交的组件比较少,所以我在这写了一个可以单选.多选标签提交的组件,调用非常简单. 代码: import React,{Fragment} from 'r ...
- 2017.11.6 - ant design table等组件的使用,以及 chrome 中 network 的使用
一.今日主要任务 悉尼小程序后台管理开发: 景点管理页面: 获取已有数据列表,选取部分数据呈现在表格中,根据景点名称.分类过滤出对应的景点. 二.难点 1. 项目技术选取: ant design. ...
- 使用Ant Design的select组件时placeholder不生效/不起作用的解决办法
先来说说使用Ant Design和Element-ui的感觉吧. 公司的项目开发中用的是vue+element-ui,使用了一通下来后,觉得element-ui虽然也有一些问题或坑,但这些小问题或坑凭 ...
- react的ant design的UI组件库
PC官网:https://ant.design/ 移动端网址:https://mobile.ant.design/docs/react/introduce-cn antd-mobile :是 Ant ...
- Ant Design的Form组件中FormItem名称相同引起的问题
1.问题描述 在使用Antd组件Form表单的过程中,会出现FormItem同名的情况,此时要特别注意同名引起的表单行为异常问题,主要表现在以下方面: (1)同名表单项的值共享,并且其中一个的值改变, ...
- ant design 的Table组件固定表头时不对齐
现在有一个表格,里面的列数是不固定的(可以重复写入数据),且列数行数都可能很多,就带来一个问题: 必须要固定表头,但是antd 的表格组件设置了固定表格 scroll={{x:1000,y:300}} ...
- Ant Design of Vue 组件库的使用
文档里面很清楚 安装步骤 这是全部引入的 1 有的组价涉及到汉化的问题 import moment from 'moment' import '../../../../node_modules ...
- react+ant design 项目执行yarn run eject 命令后无法启动项目
如何将内建配置全部暴露? 使用create-react-app结合antd搭建的项目中,项目目录没有该项目所有的内建配置, 1.执行yarn run eject 执行该命令后,运行项目yarn sta ...
- React组件库Ant Design的安装与使用
一.什么是 Ant Design 1.Ant Design 提炼自企业级中后台产品的交互语言和视觉风格 2.Ant Design 使用 TypeScript 构建,提供完整的类型定义文件 二.Ant ...
随机推荐
- P3975 [TJOI2015]弦论
思路 一眼SAM板子,结果敲了一中午... 我还是太弱了 题目要求求第k小的子串 我们可以把t=0当成t=1的特殊情况,(所有不同位置的相同子串算作一个就是相当于把所有子串的出现位置个数(endpos ...
- Shiro学习笔记(一)
首先展示一下项目的结构目录 工程是用maven创建的 主要是方便管理Jar包 maven的 pom文件中所需要的jar包 <dependencies> <dependency ...
- BZOJ 1040: [ZJOI2008]骑士(基环树dp)
http://www.lydsy.com/JudgeOnline/problem.php?id=1040 题意: 思路: 这是基环树,因为每个人只会有一个厌恶的人,所以每个节点只会有一个父亲节点,但是 ...
- 解决Geoserver请求跨域的几种思路,第二种思路用过
文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/ 1.背景描述 跨域问题是浏览器同源安全制引起的特别常见的问题.不同前端语 ...
- C++ 复习要点、面试常见问题总结
本文总结一下C++面试时常遇到的问题.C++面试中,主要涉及的考点有: 关键字极其用法,常考的关键字有const, sizeof, typedef, inline, static, extern, n ...
- iPhone 尺寸 iPhonex
http://tool.lanrentuku.com/guifan/ui.html 这是本人复制的链接,,如有不适用,,请;联系本人删除链接,,谢谢. iPhone x尺寸 1125x2436@3x ...
- jmeter3.2 版本完美实现Load Test报表
今天下载了最新版的apache tomcat jmeter 3.2,需要jdk1.8以上的版本. 用非GUI模式运行压力测试后,出现的报表太完美了. 将jmx脚本放在就jmeter_home/bin下 ...
- format格式化函数
注意:列表索引设置参数,‘0’是必须的.
- 大整数加法 HDU1002
今天早上没事干又把这个敲了一遍,虽然手冻得不行,不过又深入理解理解还可以哈. 难点就在给你的整数可能很大很长,所以long long 肯定不行,得用字符串来读取存储,然后注意一下相加的时候进位,最后输 ...
- C++.可变参数_ZC测试
ZC:环境: Win7 x64(旗舰版),Microsoft Visual Studio 2010(版本 10.0.30319.1 RTMRel, Microsoft .NET Framework(版 ...