javascript根据已知两个日期,获得两个日期之间的所有数据

传入需要开始日期和结束日期,获得这两个日期之间的所有日期
    getBetweenDateStr(start, end) {

        var result = [];
        var beginDay = start.split('-');
        var endDay = end.split('-');
        var diffDay = new Date();
        var dateList = new Array;
        var i = 0;
        diffDay.setDate(beginDay[2]);
        diffDay.setMonth(beginDay[1] - 1);
        diffDay.setFullYear(beginDay[0]);
        result.push(start);
        while(i == 0) {

            var countDay = diffDay.getTime() + 24 * 60 * 60 * 1000;
            diffDay.setTime(countDay);
            dateList[2] = diffDay.getDate();
            dateList[1] = diffDay.getMonth() + 1;
            dateList[0] = diffDay.getFullYear();
            if(String(dateList[1]).length == 1) {

                dateList[1] = '0' + dateList[1];

            }
            if(String(dateList[2]).length == 1) {

                dateList[2] = '0' + dateList[2];

            }
            result.push(dateList[0] + '-' + dateList[1] + '-' + dateList[2]);
            if(dateList[0] == endDay[0] && dateList[1] == endDay[1] && dateList[2] == endDay[2]) {

                i = 1;

            }

        }
        return result;

    }

    fromDateSearchNews = () => {

        var url = allNewList + '/' + 1;
        fetchProtect(url, {
            method: 'GET'  
        }).then((json)=>{

            if (json.code == 0) {

                let allData = json.result;
                let fromDateSearchData = [];

                let AllDate = this.getBetweenDateStr(startDate, endDate);
//遍历返回数据数组,查看返回数据中是否包含于有这两个日期之间的日期数组,如果有则将该组数据push到新的数组中
                allData.forEach((item) => {

                    let currentDate = item.creat_time.slice(0, 10);

                    if(AllDate.indexOf(currentDate) > -1) {

                        fromDateSearchData.push(item);

                    }else {

                        return;

                    }

                });

                this.setState({
                    allDataNew: [...fromDateSearchData]
                });

            }

        });

    }
    dateChange = (value) => {

        startDate = value[0].format(dateFormat);
        endDate = value[1].format(dateFormat);

    }

render中:

render() {
    <div>
    <Col className='gutter-row' md={8} lg={8} xl={5}>
      <FormItem labelCol={{span: 5}} wrapperCol={{span: 19}} label='创建时间' >
         <RangePicker 
                 onChange={this.dateChange}/>
       </FormItem>
   </Col>
  <Col className='gutter-row' md={4} lg={4} xl={7}>
      <Button type='primary' size='large' onClick={this.fromDateSearchNews}>查询</Button>
  </Col>
</div>
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值