momentJS减法moment.subtract 改变自身值

需求
在下方选中时间段
在这里插入图片描述
然后在图标这里显示 选中的时间段内的每一天日期
在这里插入图片描述
思路:算出时间差 然后一天天往前退 列出每一天

想先在componentDidMount试试能不能拿到值
在这里插入图片描述
但是 拿到的结果却不对
在这里插入图片描述
在这里插入图片描述
从i=2的时候 就选出的日期不对了
后续断点发现 .subtract方法改变了本身的值
查资料发现 需要用moment(time)包起来
原本以为 给的time 已经是moment实例了 就没有又包一层

正确代码

 const { rangeTime } = this.state;
    const range = rangeTime[1].diff(rangeTime[0]);
    const d = moment.duration(range);
    const days = d.asDays() + 1;
    const data = [];
    for (let i = 0; i < parseInt(days); i++) {
      data.push(moment(rangeTime[1]).subtract(i, 'days').format('YYYY-MM-DD'));
    }

    console.log('时间差', days, data);

就可以获得时间段内的每一天日期了

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值