js导入 excel日期 time.getDate()-1 会少一天

解决 js excel转日期 time.getDate()-1 会少一天的问题;

excel导入表格,日期发现少一天。关键问题在于要区分闰年与平年;

    //js 读取EXCEL中的日期类型时,需要日期转换
    //excel读取2018/01/01这种时间格式是会将它装换成数字类似于46254.1545151415 numb是传过来的整数数字
    excelFormatDate(numb) {
      const time = new Date((numb - 1) * 24 * 3600000 + 1);
      time.setYear(time.getFullYear() - 70);
      const year = time.getFullYear() + "";
      const month = time.getMonth() + 1 + "";

      let date = time.getDate() + "";

      // if ( this.leapyear(year) ) {
      //   //如果是闰年
      //   date = time.getDate() - 1 + "";
      // }
      if ( !this.leapyear(year) && year!=='2023') { //2023年比较特殊
        //如果是平年 20231227
        date = time.getDate() - 1 + "";
      }

      return (
        year +
        "-" +
        (month < 10 ? "0" + month : month) +
        "-" +
        (date < 10 ? "0" + date : date)
      );
    },


  //区分闰年与平年
    leapyear(year) {
      var flag = false;
      if ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0) {
        flag = true;
      }
      return flag;
    },

之前写的是闰年就 -1 天,但是2024发现有问题;

经过大量数据导入测试

1月12日

2020 闰年 12日
2021 平年 13日
2022 平年 13日
2023 平年 12日   是闰年,但有闰二月
2024 闰年 12日
2025 平年 13日
2028 闰年 12日

可以发现2023年比较特殊,所有的平年都会多1天,但是2023年刚刚好

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值