记录工作遇到时间的各种处理

74 篇文章 3 订阅

1.vant中倒计时处理

效果
在这里插入图片描述

由于vant返回的就是HH: mm : ss 格式,所以切割就可以了,如果返回的是其他格式例如2021-4-17之类的,就得先加入new Date()中,再分别取出年月日切割.

        <!-- 引入倒计时 -->
        <van-count-down :time="time" format="HH: mm : ss ">
          <template #default="timeData">
            <span class="countDownBlock">{{
              timeData.hours | dateFormat("1")
            }}</span>
            <span class="countDownBlock">{{
              timeData.hours | dateFormat("2")
            }}</span>
            <span class="countDownColon">:</span>
            <span class="countDownBlock">{{
              timeData.minutes | dateFormat("1")
            }}</span>
            <span class="countDownBlock">{{
              timeData.minutes | dateFormat("2")
            }}</span>
            <span class="countDownColon">:</span>
            <span class="countDownBlock">{{
              timeData.seconds | dateFormat("1")
            }}</span>
            <span class="countDownBlock">{{
              timeData.seconds | dateFormat("2")
            }}</span>
          </template>
        </van-count-down>
 filters: {
    // 过滤成单个时间,如果不满10,就加上0
    dateFormat(value, type) {
      let data = value.toString();
      data = data < 10 ? "0" + data : data;
      if (type == 1) {
        let filterDate = data.slice(0, 1);
        return filterDate;
      } else {
        let filterDate = data.slice(1, 2);
        return filterDate;
      }
    },

2.格式化日期yyyy-MM

这里获得的格式就是Sat Apr 17 2021 17:12:46 GMT+0800 (中国标准时间)类型,如果不是,如上所述,需要先转化,例如:new Date(date)

  formatTime(date) {
      var YY = date.getFullYear();
      var MM =
        date.getMonth() + 1 < 10
          ? "0" + (date.getMonth() + 1)
          : date.getMonth() + 1;
      return YY + "-" + MM;
    },

3.yyyy MM转为yyyy年MM月

spe切割的是标点符号,比如2021-04中的"-",2021.04中的"."

  selectTime(value, spe) {
      let date = value.split(spe);
      return `${date[0]}${date[1]}`;
    },

4.日期相加或相减获取截止时间

这里是传入年月日,返回数组形式的年月日,可以根据业务做调整

    gettime(vyear, vmonth, vday) {
      var date = new Date();
      var nyear = date.getFullYear() + vyear; //获取年份差
      var nmonth = date.getMonth() + vmonth; //获取月份差
      var nday = date.getDate() + vday; //获取日差
      var ux = Date.UTC(nyear, nmonth, nday); //转化为时间戳
      var date1 = new Date(ux); //构造目标日期
      return [date1.getFullYear(), date1.getMonth() + 1, date1.getDate()];
    },

5.格式化时间yyyy-MM-dd hh:MM:ss

formatDate(date) {
      var date = new Date(date);
      var YY = date.getFullYear() + "-";
      var MM =
        (date.getMonth() + 1 < 10
          ? "0" + (date.getMonth() + 1)
          : date.getMonth() + 1) + "-";
      var DD = date.getDate() < 10 ? "0" + date.getDate() : date.getDate();
      var hh =
        (date.getHours() < 10 ? "0" + date.getHours() : date.getHours()) + ":";
      var mm =
        (date.getMinutes() < 10 ? "0" + date.getMinutes() : date.getMinutes()) +
        ":";
      var ss =
        date.getSeconds() < 10 ? "0" + date.getSeconds() : date.getSeconds();
      return YY + MM + DD + " " + hh + mm + ss;
    },

6.根据某个时间判断是否在区间时间内


    /**
     * @method 根据时间判断问候语
     */
    judgeTime() {
      let time = [
        {
          start: "05:00",
          end: "07:59",
          timeToast: "早上好",
        },
        {
          start: "08:00",
          end: "11:59",
          timeToast: "上午好",
        },
        {
          start: "12:00",
          end: "13:59",
          timeToast: "中午好",
        },
        {
          start: "14:00",
          end: "18:59",
          timeToast: "下午好",
        },
        {
          start: "19:00",
          end: "04:59",
          timeToast: "晚上好",
        },
      ];
      this.timeToast = time.find((item) =>
        this.isDuringDate(item.start, item.end)
      ).timeToast;
    },

    /**
     * [isDuringDate 比较当前时间是否在指定时间段内]
     * @DateTime 2021/05/26
     * @version  1.0
     * @param {String}  beginDateStr 开始时间
     * @param {String}  endDateStr   结束时间
     * @return   Boolean
     */
    isDuringDate(beginDateStr, endDateStr) {
      let curDate = `${new Date().getHours()}:${
        new Date().getMinutes() < 10
          ? "0" + new Date().getMinutes()
          : new Date().getMinutes()
      }`;
   return (
        (curDate >= beginDateStr
          ? true
          :  beginDateStr == "19:00") &&
        (curDate <= endDateStr
          ? true
          : endDateStr == "04:59")
      );
    },
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当你在正式环境中遇到问题时,以下是一些处理问题的步骤: 1. 确认和复现问题:首先,确认问题是可复现的,并且能够准确地描述问题的出现条件和现象。这将有助于你更好地理解问题的本质。 2. 日志和错误信息:查看相关的日志文件和错误信息,以了解更多关于问题的细节。这些信息可能会提供有关问题原因的线索。 3. 问题分析和诊断:使用适当的工具和技术,对问题进行分析和诊断。这可能包括检查数据库的状态、执行查询计划分析、跟踪日志、监测系统性能等。根据具体情况,选择合适的方法来定位和解决问题。 4. 问题解决方案:根据问题的分析结果,制定解决方案。这可能包括修复代码错误、优化查询、调整配置参数、更新数据库版本等。选择合适的解决方案,并进行相应的测试验证。 5. 风险评估和计划:评估解决方案的风险,并制定合理的实施计划。考虑到正式环境的稳定性和业务影响,确保在实施过程中最小化风险,并制定回滚计划以备不时之需。 6. 实施和验证:在适当的时间窗口内,按计划实施解决方案。在完成实施后,验证问题是否解决,并确保系统正常运行。 7. 监测和预防:持续监测系统的运行情况,确保问题的解决持久有效。同时,总结问题的原因和解决方法,制定预防措施,以避免类似问题再次发生。 8. 寻求帮助:如果你在处理问题的过程中遇到困难或需要进一步的专业支持,不要犹豫寻求帮助。你可以咨询相关技术团队、数据库厂商的支持服务或社区论坛等。 重要的是要有耐心和系统性地解决问题。在处理问题时,确保记录下所有关键步骤和结果,以便将来参考和分享经验。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值