微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

完整日历 V4 - 单击事件时,如何更改日期的颜色

如何解决完整日历 V4 - 单击事件时,如何更改日期的颜色

我正在使用月视图。我显示所有日期,我想将每一天标记为“工作日”、“加班日”、“假期”等。

我将上面的每个标签都设置为事件,并且显示正常。我的下一个目标是选择一个日期并申请休假。当我单击一天时,它会触发 dateClick 并将背景颜色更改为绿色。如果我再次选择相同的日期,我会将背景颜色改回白色。这给人一种用户选择/取消选择日期的感觉。可以像这样选择多个日期,颜色会变成绿色,我会维护一个选定日期的列表。

if (info.dayEl.style.backgroundColor == 'green') {
    info.dayEl.style.backgroundColor = 'white';
  } else {
    info.dayEl.style.backgroundColor = 'green';
  }

问题:当我点击一天中的事件(如加班等)时,我无法更改当天整个单元格的背景颜色。

一个事件被点击时,eventClick 被触发,在该函数中我尝试通过执行触发“选择”

this.fullCalendarMonthly.getCalendar().select(info.event.start);

但它没有任何 html 元素和样式。

还有其他方法可以实现吗?

解决方法

在事件点击时,我使用 css 类循环来完成它。

var week = info.el.closest(".fc-content-skeleton").closest(".fc-week");
var days = week.querySelectorAll(".fc-day");
days.forEach(day => {
  if (day.attributes["data-date"].value == currentDate) {
      day.style.backgroundColor = '#123';
  }
}); 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。