Vue Material Year Calendar插件:activeDates.push()后日历未选中,如何解决?

vue material year calendar插件:activedates.push()后日历未选中,如何解决?

Vue Material Year Calendar 插件 activeDates.push() 后日历未更新选中状态的解决方案

使用 vue-material-year-calendar 插件时,开发者常遇到将日期添加到 activeDates 数组后,日历未更新选中状态的问题。本文将分析原因并提供 Vue 2 和 Vue 3 的解决方案。

问题描述:

按照文档示例,使用 activeDates.sync 指令绑定 activeDates 数组,并通过 push 方法添加日期,期望更新日历选中状态,但日历界面未显示选中效果。

立即学习“前端免费学习笔记(深入)”;

代码示例 (Vue 2):

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


并确保 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 的值是关键。

以上就是Vue Material Year Calendar插件:activeDates.push()后日历未选中,如何解决?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1503086.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月20日 01:31:14
下一篇 2025年12月20日 01:31:30

相关推荐

发表回复

登录后才能评论
关注微信