Vue Material Year Calendar 插件 activeDates.push() 后日历未更新选中状态的解决方案
使用 vue-material-year-calendar 插件时,开发者常遇到将日期添加到 activeDates 数组后,日历未更新选中状态的问题。本文将分析原因并提供 Vue 2 和 Vue 3 的解决方案。
问题描述:
按照文档示例,使用 activeDates.sync 指令绑定 activeDates 数组,并通过 push 方法添加日期,期望更新日历选中状态,但日历界面未显示选中效果。
代码示例 (Vue 2):
<yearcalendar :activeclass="activeclass" :activedates.sync="activedates" prefixclass="your_customized_wrapper_class" v-model="year"></yearcalendar> data() { return { year: 2019, activedates: [ { date: '2019-02-13' }, { date: '2019-02-14', classname: 'red' }, // ... ], activeclass: '', }; }, toggledate(dateinfo) { const index = this.activedates.indexOf(dateinfo); if (index === -1) { this.activedates.push(dateinfo); } else { this.activedates.splice(index, 1); } }
问题原因:
activeDates.sync 在 Vue 2 和 Vue 3 中行为不同。直接使用 push 方法,Vue 无法可靠地检测到数组变化并重新渲染日历。
解决方案:
Vue 2: 移除 .sync 修饰符,直接使用 :activedates:
<yearcalendar :activeclass="activeclass" :activedates="activedates" prefixclass="your_customized_wrapper_class" v-model="year"></yearcalendar>
并确保 toggledate 函数正确更新 activedates 数组。可以使用 this.$set(this.activedates, this.activedates.length, dateinfo) 来强制 Vue 重新渲染。
Vue 3: 使用 ref 并添加 selected 属性:
import { ref } from 'vue'; const activeDates = ref([ { date: '2024-02-13', selected: true, className: '' }, { date: '2024-02-14', selected: false, className: 'red' }, // ... ]);
toggledate 函数需修改 activeDates.value 中对象的 selected 属性:
function toggledate(dateinfo) { const existingDate = activeDates.value.find(date => date.date === dateinfo.date); if (existingDate) { existingDate.selected = !existingDate.selected; } else { activeDates.value.push({ ...dateinfo, selected: true }); } }
通过这些调整,vue-material-year-calendar 插件将正确识别 activeDates 数组的变化,并更新日历的选中状态。 确保你的数据结构与插件的期望相符。 Vue 3 中,直接操作 ref 的值是关键。