web日程功能开发问题台账!

最近在做日程功能,用到了时间插件moment和elementUI的日历组件el-calendar。在使用过程中,遇到一点小问题,在此记录一下。

一、moment()不规范传参

在开发中,经常会用moment()格式化时间,知道moment支持的参数类型比较多,包括日期和时间字符串、时间戳、JavaScript对象和moment对象等,一直以来使用也没有问题。

最近在开发日程功能中,需要将年、月、日三个字段手动拼接成一个时间字符串, 拼接结果如下:

js 复制代码
time = '2024-3-1'

想着拼接的结果不符合后端时间传参"YYYY-MM-DD"的格式要求,便想着用moment()的格式化一下。

js 复制代码
moment(time).format('YYYY-MM-DD')

结果控制台出现如下警告。

无奈,只得手动将小于10的月、日前补0如2024-03-01,补0后再moment()格式化,就没有上述警告了。

二、calendar绑定值不规范赋值

calendar组件是第一次用。

需求中要求点击日期单元格请求接口获取对应日期的日程安排。calendar组件未提供点击事件,所以需要结合calendar组件自定义内容功能自定义点击事件。

然后对照着文档写下了如下代码:

js 复制代码
<template>
  <el-calendar v-model="selectDay">
    <template
       slot="dateCell"
       slot-scope="{date, data}"
     >
       <div class="day-box" @click="handleDateChange(date)">
         <div class="day-num">{{ moment(data.day).format('D')}}</div>
         <div class="day-dot" v-if="data.type === 'current-month'"></div>
       </div>
     </template>
  </el-calendar>
 </template>
 
 <script>
 export default {
    data(){
       selectDay: '',
    },
    methods: {
      handleDateChange(date) {
         this.selectDay = moment(date).format('YYYY-MM-DD');
         this.getScheduleList()
      },
      async getScheduleList() {
        try {
          const params = {
            queryDate: moment(this.selectDay).format('YYYY-MM-DD),
          };
        } catch(e) {
        };
      },
    }
 }
 </script>
  

再然后进行切换日期操作。在面板当前月的日期中来回点击没有问题,但点击面板中上一个月或下一个月的日期(如下图红框圈出来的日期)时,跳转到对应上一个或下一个月的选中日期非之前点击的日期。

经过排查,发现是在handleDateChange事件中对组件的绑定值this.selectDay重新赋值所致。也就是说,在日期点击事件中,不能对日期绑定值重新赋值,否则会引起选中错乱的问题。

找到原因,将代码调整:绑定值字段与接口传参字段分开。

js 复制代码
handleDateChange(date) {
  this.queryDay = moment(date).format('YYYY-MM-DD');
  this.getScheduleList()
 },
 async getScheduleList() {
   try {
      const params = {
         queryDate: moment(this.queryDay).format('YYYY-MM-DD),
      };
    } catch(e) {
    };
  },

为什么要加一个接口传参字段queryDay呢?直接将绑定值selectDay传给接口不行吗?

不行。因为handleDateChange发生时,selectDay的绑定值还是上一次选中的日期。

相关推荐
万少2 小时前
HarmonyOS官方模板集成创新活动-流蓝卡片
前端·harmonyos
-To be number.wan5 小时前
C++ 赋值运算符重载:深拷贝 vs 浅拷贝的生死线!
前端·c++
噢,我明白了5 小时前
JavaScript 中处理时间格式的核心方式
前端·javascript
纸上的彩虹6 小时前
半年一百个页面,重构系统也重构了我对前端工作的理解
前端·程序员·架构
be or not to be6 小时前
深入理解 CSS 浮动布局(float)
前端·css
LYFlied7 小时前
【每日算法】LeetCode 1143. 最长公共子序列
前端·算法·leetcode·职场和发展·动态规划
老华带你飞7 小时前
农产品销售管理|基于java + vue农产品销售管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
小徐_23337 小时前
2025 前端开源三年,npm 发包卡我半天
前端·npm·github
C_心欲无痕7 小时前
vue3 - 类与样式的绑定
javascript·vue.js·vue3
GIS之路8 小时前
GIS 数据转换:使用 GDAL 将 Shp 转换为 GeoJSON 数据
前端