vue+elementui实现12个日历平铺,初始化工作日,并且可点击

<template><div class="app-container"><el-form :model="queryParams" ref="queryForm" size="small" :inline="true"><el-form-item label="年份" prop="holidayYear"><el-date-pickerv-model="queryParams.holidayYear"type="year":clearable="false"placeholder="选择年"></el-date-picker></el-form-item><el-form-item><el-buttontype="primary"icon="el-icon-search"size="mini"@click="handleQuery">搜索</el-button><el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button></el-form-item></el-form><el-row><el-button type="primary" @click="submitClickedDates">提交</el-button><div v-for="(cal, index) in defaultCals" :key="index"><el-col :span="6"><el-calendar :value="cal" class="holiday"><template slot="dateCell" slot-scope="{ date, data }"><divclass="holiday-cell"v-show="data.type === 'current-month'":id="cal.getMonth() + '-' + data.day"@click="selectCalendarDate(cal, data)":style="{ backgroundColor: getCellBackgroundColor(cal, data) }">{{ data.day.split("-")[2] }}</div></template></el-calendar></el-col></div></el-row></div>
</template><script>
export default {// name: "temp",data() {return {queryParams: {holidayYear: new Date(),},//设置的月份defaultCals: [],// 全年已选中的日期holidayDate: [],clickedDates: [], // 记录点击的日期selectedDates: [], // 初始选中的日期数组};},created() {//初始化日历let nowYear = new Date().getFullYear();this.initCalendar(nowYear + 1);// 初始化日历// let nowYear = new Date().getFullYear();// this.currentMonth = new Date(); // 明确初始化this.currentMonth// this.initCalendar(nowYear + 1);},methods: {// 根据给定的年份获取一年中周一到周五的日期数组getWeekdays(year) {const weekdays = [];const currentDate = new Date(year, 0, 1); // 设置为给定年份的第一天// 遍历一年中的每一天while (currentDate.getFullYear() === year) {const dayOfWeek = currentDate.getDay();// 如果是周一到周五,将日期格式化并添加到数组中if (dayOfWeek >= 1 && dayOfWeek <= 5) {const formattedDate = `${currentDate.getFullYear()}-${(currentDate.getMonth() + 1).toString().padStart(2, "0")}-${currentDate.getDate().toString().padStart(2, "0")}`;weekdays.push(formattedDate);}// 将日期增加一天currentDate.setDate(currentDate.getDate() + 1);}return weekdays;},//初始化日历initCalendar(year) {this.defaultCals = [new Date(year, 0, 1),new Date(year, 1, 1),new Date(year, 2, 1),new Date(year, 3, 1),new Date(year, 4, 1),new Date(year, 5, 1),new Date(year, 6, 1),new Date(year, 7, 1),new Date(year, 8, 1),new Date(year, 9, 1),new Date(year, 10, 1),new Date(year, 11, 1),];//调接口获取this.holidayDate = this.getWeekdays(year);console.log(this.holidayDate);// 转化为对象数组const formattedDates = this.holidayDate.map((date) => {const dateObj = new Date(date);return {cal: dateObj,data: {day: date,isSelected: false,type: "current-month",},};});console.log(formattedDates);console.log("chushihua");this.clickedDates = formattedDates;this.$nextTick(() => {let holidayCell = document.getElementsByClassName("holiday-cell");for (let i in holidayCell) {if (undefined != holidayCell[i].style) {holidayCell[i].style.backgroundColor = "#FFFFFF";}}//给已选中的日期加背景色for (let i in this.holidayDate) {const month = parseInt(this.holidayDate[i].split("-")[1]) - 1;let span = document.getElementById(month + "-" + this.holidayDate[i]);span.style.backgroundColor = "#F56C6C";}});},/** 搜索按钮操作 */handleQuery() {let year = this.queryParams.holidayYear.getFullYear();this.initCalendar(year);},/** 重置按钮操作 */resetQuery() {this.resetForm("queryForm");this.queryParams.holidayYear = new Date();this.handleQuery();},// 获取日期单元格的背景颜色getCellBackgroundColor(cal, data) {console.log("获取日期单元格的背景颜色");const clickedDate = this.clickedDates.find((clickedDate) => {return (clickedDate.cal.getFullYear() === cal.getFullYear() &&clickedDate.cal.getMonth() === cal.getMonth() &&clickedDate.data.day === data.day);});return clickedDate ? "#F56C6C" : "#FFFFFF";},// 点击日期单元格的事件selectCalendarDate(cal, data) {const clickedDateIndex = this.clickedDates.findIndex((clickedDate) => {console.log(clickedDate);return (clickedDate.cal.getFullYear() === cal.getFullYear() &&clickedDate.cal.getMonth() === cal.getMonth() &&clickedDate.data.day === data.day);});if (clickedDateIndex !== -1) {// 如果日期已经被点击过,移除记录并取消背景色this.clickedDates.splice(clickedDateIndex, 1);} else {// 否则,记录点击的日期this.clickedDates.push({ cal, data });}console.log(this.clickedDates);},// 提交按钮点击事件submitClickedDates() {const formattedDates = this.clickedDates.map((clickedDate) => {const date = clickedDate.data.day;const formattedDate = `${clickedDate.cal.getFullYear()}-${date.split("-")[1]}-${date.split("-")[2]}`;return formattedDate;});// 在这里处理格式化后的日期数组console.log("Formatted Dates:", formattedDates);// let dates = ['2025-01-01', '2025-01-06', '2025-01-07', '2025-01-08', '2025-01-10'];// 将日期字符串转换为 Date 对象// let dateObjects = dates.map(dateString => new Date(dateString));// // 按照 Date 对象进行排序// dateObjects.sort((a, b) => a - b);// // 将排序后的 Date 对象转换回日期字符串// let sortedDates = dateObjects.map(date => date.toISOString().split('T')[0]);// console.log(sortedDates);},},
};
</script><style>
.holiday .el-calendar__button-group {display: none;
}.select-month .el-calendar__button-group {display: none;
}.holiday .el-calendar-day {padding: 1px;width: 100%;height: 34px;
}.select-month .el-calendar-day {padding: 1px;width: 100%;
}.holiday-cell {width: 100%;height: 100%;display: flex;justify-content: center;align-items: center;
}
</style>

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/241007.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

93.乐理基础-记号篇-装饰音记号(一)级进、跳进、经过音、辅助音

内容参考于&#xff1a;三分钟音乐社 上一个内容&#xff1a;92.乐理基础-记号篇-演奏记号&#xff08;三&#xff09;刮奏、琶音-CSDN博客 首先 级进 与 跳进 1.级进指的是忽略掉所有升降号&#xff0c;如果两个音之间不存在其它的唱名&#xff0c;那前一个音到后一个音就成…

Android中矩阵Matrix实现平移,旋转,缩放和翻转的用法详细介绍

一&#xff0c;矩阵Matrix的数学原理 矩阵的数学原理涉及到矩阵的运算和变换&#xff0c;是高等代数学中的重要概念。在图形变换中&#xff0c;矩阵起到关键作用&#xff0c;通过矩阵的变换可以改变图形的位置、形状和大小。矩阵的运算是数值分析领域的重要问题&#xff0c;对…

面试题 05.06. 整数转换(力扣)(OJ题)

题目链接&#xff1a;面试题 05.06. 整数转换 - 力扣&#xff08;LeetCode&#xff09; 所属专栏&#xff1a;刷题 整数转换。编写一个函数&#xff0c;确定需要改变几个位才能将整数A转成整数B。 示例1: 输入&#xff1a;A 29 &#xff08;或者0b11101&#xff09;, B 15…

浅谈对Maven的理解

一、什么是Maven Maven——是Java社区事实标准的项目管理工具&#xff0c;能帮你从琐碎的手工劳动中解脱出来&#xff0c;帮你规范整个组织的构建系统。不仅如此&#xff0c;它还有依赖管理、自动生成项目站点等特性&#xff0c;已经有无数的开源项目使用它来构建项目并促进团队…

供应链共舞:数字化协同推动服装企业商品计划的无缝衔接

在数字化时代&#xff0c;服装企业不再是孤立经营的个体&#xff0c;而是在供应链共舞的大舞台上实现了商品计划的无缝衔接。数字化协同不仅改变了企业内部的运营方式&#xff0c;更深刻地重塑了整个供应链的协同模式。以下探讨数字化协同如何推动服装企业商品计划实现无缝衔接…

MySQL存储函数与存储过程习题

创建表并插入数据&#xff1a; 字段名 数据类型 主键 外键 非空 唯一 自增 id INT 是 否 是 是 否 name VARCHAR(50) 否 否 是 否 否 glass VARCHAR(50) 否 否 是 否 否 ​ ​ sch 表内容 id name glass 1 xiaommg glass 1 2 xiaojun glass 2 1、创建一个可以统计表格内记录…

mybatisPlus注解将List集合插入到数据库

1.maven引入依赖&#xff08;特别注意版本&#xff0c;3.1以下不支持&#xff09; <dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.4.3.1</version></dependency&g…

Docker容器添加映射端口

方式一 简单粗暴&#xff08;需要等一段时间&#xff09; 直接给现在容器停了&#xff08;当然你要不想停也可以&#xff0c;只是打包会慢一点&#xff0c;当然我是没出意外&#xff0c;如果你怕出现特殊情况&#xff0c;那就先把容器停了&#xff09;&#xff0c;然后把这个容…

FFmpeg之AVFilter

文章目录 一、概述二、重要结构体2.1、AVFilterGraph2.2、AVFilter2.3、AVFilterContext 三、流程梳理3.1、FFmpeg AVFilter 使用整体流程3.2、过滤器构建流程3.2.1、分配AVFilterGraph3.2.2、创建过滤器源3.2.3、创建接收过滤器3.2.4、生成源和接收过滤器的输入输出3.2.5、通过…

React配置src根目录@

文章目录 1.打开webpack配置文件2.配置webpack 1.打开webpack配置文件 yarn eject or npm run eject 如果报错了记得提前 git commit一下 2.配置webpack 找到 webpack.config.js 文件在 webpack.config.js 文件中找到 alias 配置在alias里添加: path.resolve(src) , 或者 : pa…

JVM:垃圾回收机制(GC)

垃圾判断&#xff1a; 引用计数算法&#xff1a; 在对象中添加一个引用计数器&#xff0c;当每有一个地方引用它时&#xff0c;计数器值加一。当引用失效时&#xff0c;计数器值就减一。当一个对象的计数器为零时&#xff0c;表示该对象没有被任何其他对象引用&#xff0c;因此…

C语言从入门到实战——结构体与位段

结构体与位段 前言一、结构体类型的声明1.1 结构体1.1.1 结构的声明1.1.2 结构体变量的创建和初始化 1.2 结构的特殊声明1.3 结构的自引用 二、 结构体内存对齐2.1 对齐规则2.2 为什么存在内存对齐2.3 修改默认对齐数 三、结构体传参四、 结构体实现位段4.1 什么是位段4.2 位段…

gitgud.io+Sapphire注册账号教程

gitgud.io是一个仓库&#xff0c;地址 https://gitgud.io/&#xff0c;点进去之后会看到注册页面。 意思是需要通过注册这个Sapphire账户来登录。点击右边的Sapphire&#xff0c;就跳转到Sapphire的登陆页面&#xff0c;点击创建新账号&#xff0c;就进入注册页面。&#xff0…

Qt拖拽组件与键盘事件

1.相关说明 1.设置widget或view的拖拽和放置模式函数setDragDropMode参数说明&#xff0c;NoDragDrop(无拖拽和放置)、DragOnly(只允许拖拽)、DropOnly(只允许放置)、DragDrop(允许拖拽和放置)、InternalMove(只移动不复制) 2.设置widget或view的放置动作函数setDefaultDropAct…

Elastic Stack 8.12:通过对 ES|QL 等的改进增强了向量搜索

作者&#xff1a;来自 Elastic Tyler Perkins, Shani Sagiv, Gilad Gal, Ninoslav Miskovic Elastic Stack 8.12 构建于 Apache Lucene 9.9&#xff08;有史以来最快的 Lucene 版本&#xff09;之上&#xff0c;基于我们对标量量化和搜索并发性的贡献&#xff0c;为文本、向量和…

SQL 最大连续合格次数 最大连胜记录次数 最大连败记录次数

有这样一个问题&#xff0c;工厂中要统计某个供应商送货检验的情况&#xff0c;依照其连续合格次数&#xff0c;决定是否免检&#xff0c;不使用游标或者循环&#xff0c;如何写这个sql。 此情景也可以用于统计连胜记录等 先要学习一下 窗函数LAG&#xff0c;指的是按分组和排…

Leetcode刷题【每日n题】(3)

&#x1f3b5;今日诗词&#x1f3b5; 桃花潭水深千尺&#xff0c;不及汪伦送我情。 ——李白《赠汪伦》 目录 1.题目一 2.思路分析 3.代码实现 4.题目二 5.思路分析 6.代码实现 1.题目一 9. 回文数 给你一个整数 x &#xff0c;如果 x 是一个回文整数&#xff0c;返回 tr…

vue3-表单输入绑定

表单输入绑定 获取表单输入的值方式&#xff1a; 手动连接值绑定和更改事件监听器 v-model 指令 &#xff08;常用&#xff09; <script lang"ts" setup> import { ref } from "vue" // 定义个变量接收输入的内容&#xff1a; const text ref(&…

Oracle 数据库备份与恢复的重要性与最佳实践

文章目录 一、备份的重要性二、备份工具-RMAN四、比较备份策略五、实例恢复六、完全恢复与不完全恢复七、备份与恢复脚本 引言&#xff1a; 在现代信息时代&#xff0c;数据已成为组织和企业最重要的资产之一。保护和恢复数据的能力对于确保业务连续性和减少潜在风险至关重要。…

[足式机器人]Part2 Dr. CAN学习笔记- Kalman Filter卡尔曼滤波器Ch05-5+6

本文仅供学习使用 本文参考&#xff1a; B站&#xff1a;DR_CAN Dr. CAN学习笔记 - Kalman Filter卡尔曼滤波器 Ch05-56 5. An Example 2D例子6. Extended Kalman Filter扩展卡尔曼滤波器&#xff08;EKF&#xff09; 5. An Example 2D例子 6. Extended Kalman Filter扩展卡尔曼…