vue3+element-plus实现日历组件农历显示且带列表数据

news2024/11/17 15:27:00

在这里插入图片描述
calendar.js
https://gitee.com/mirrors/calendar-js.git 这个js可以去下载,里面涉及的有点多

要设置日历每周以周一开始,需要在main.js中加入这一行代码
在这里插入图片描述

import 'dayjs/locale/zh-cn'; // 设置日历每周从周一开始
<template>
 <ELPlusLanguageConfig :local="local">
	<el-calendar v-model="newData" class="dialog-calendar">
	 <template #header="{ date }">
	     <div class="font18" style="color: var(--color6)">{{ date }}</div>
	     <div class="view-btn">
	       <span class="pointer active">单期查看</span>
	       <span @click="goPage('/DataWrite/DataEditCompare',{id:123,c:true})" class="pointer">
	         对比查看
	       </span>
	     </div>
	 </template>
	 <template #dateCell="{ date, data }">
	   <el-row>
	     <el-col class="datastyle">
	       <span>{{ data.day.split("-").slice(2).join("-") }}</span>
	       <span class="marginL10">{{ solarToLunar(date, data) }}</span>
	     </el-col>
	   </el-row>
	   <template v-for="(item, index) in textContent(data.day)" :key="index">
	     <div v-for="(list, ind) in item.list.slice(0, 4)" :key="ind" class="paddingV5 item-list ellipsis">{{ list.name }}</div>
	     <!-- 每个日期下面最多显示4条填报信息,超过4条显示分页 -->
	     <div v-if="item.list.length > 4" class="flex items-center justify-end">
	       <div class="marginR10 item-page">
	         <span style="color:#262626;">{{ item.currentPage }}</span>
	         <span style="color:#999;margin: 0 1px;">/</span>
	         <span style="color:#999;">{{ item.totalPage }}</span>
	       </div>
	       <div style="color:var(--fontColor);font-weight: 550;">
	         <span class="pointer marginR10" @click.stop="prevPage(item.day)">&lt;</span>
	         <span class="pointer" @click.stop="nextPage(item.day)">&gt;</span>
	       </div>
	     </div>
	   </template>
	 </template>
	</el-calendar>
 </ELPlusLanguageConfig>
</template>


<script setup>
import {ref, reactive} from "vue";
import {useRouter} from "vue-router";
import ELPlusLanguageConfig from '@/components/ELPlusLanguageConfig'
import calendarUtils from '@/utils/calendar/calendar'
import useWeeks from '@/utils/useWeeks'

// 日历相关 start --------
const newData = ref(new Date())
let valueFormat = 'YYYY-MM'
const local = useWeeks(valueFormat);

const router = useRouter();
const props = defineProps({
  showDialog:{
    type:Boolean,
    default:false
  }
})
const form = ref();
const emit = defineEmits()
const doClose = () => {
  emit('update:showDialog',false)
}
const goPage = (path,query = {}) => {
  router.push({
    path,
    query
  })
}
const submit = () => {
  emit('onSubmit',form.value)
  doClose()
}

const state = reactive({
  //测试数据
  calendarData: [
    {
      day: "2023-07-04",
      list: [
        {
          name: '已填报单位名称1已填报单位名称1已填报单位名称1已填报单位名称1已填报单位名称1'
        },
        {
          name: '已填报单位名称1'
        },
        {
          name: '已填报单位名称1'
        },
        {
          name: '已填报单位名称1'
        }
      ],
      currentPage: 1,
      totalPage: 5,
    },
    {
      day: "2023-07-05",
      list: [
        {
          name: '已填报单位名称1'
        },
        {
          name: '已填报单位名称1'
        },
        {
          name: '已填报单位名称1'
        },
        {
          name: '已填报单位名称1'
        },
        {
          name: '已填报单位名称1'
        }
      ],
      currentPage: 1,
      totalPage: 5,
    },
    {
      day: "2023-07-06",
      list: [
        {
          name: '已填报单位名称1'
        },
        {
          name: '已填报单位名称1'
        },
        {
          name: '已填报单位名称1'
        },
        {
          name: '已填报单位名称1'
        },
        {
          name: '已填报单位名称1'
        }
      ],
      currentPage: 1,
      totalPage: 5,
    },
    {
      day: "2023-07-07",
      list: [
        {
          name: '已填报单位名称1'
        },
        {
          name: '已填报单位名称1'
        },
        {
          name: '已填报单位名称1'
        },
        {
          name: '已填报单位名称1'
        }
      ],
      currentPage: 1,
      totalPage: 5,
    },
  ],
});

const textContent = (date) => {
  //当前date是拿到上面日历组件当前的日期值 根据该值去筛选测试数据找到对应各个日期下对应的数据return出去
  return state.calendarData.filter((item) => {
    return date === item.day;
  });
}

// 公历转农历
const solarToLunar = (slotDate, slotData) => {
  let solarDayArr = slotData.day.split('-');
  let lunarDay = calendarUtils.solar2lunar(solarDayArr[0], solarDayArr[1], solarDayArr[2])
  // 农历日期
  // let lunarMD = lunarDay.IMonthCn + lunarDay.IDayCn

  // 公历节日\农历节日\农历节气
  // let festAndTerm = [];
  // festAndTerm.push(lunarDay.festival == null ? '' : ' ' + lunarDay.festival)
  // festAndTerm.push(lunarDay.lunarFestival == null ? '' : '' + lunarDay.lunarFestival)
  // festAndTerm.push(lunarDay.Term == null ? '' : '' + lunarDay.Term)
  // festAndTerm = festAndTerm.join('')
  // return festAndTerm == '' ? lunarMD : festAndTerm
  return lunarDay.IDayCn
}
// 上一页
const prevPage = (day) => {
  let calendarData = state.calendarData;
  for (let i = 0; i <calendarData.length; i++ ) {
    let items = calendarData[i];
    if (items.day == day) {
      if (items.currentPage === 1) {
        items.currentPage = 1
      } else {
        items.currentPage--
      }
    }
  }
}
// 下一页
const nextPage = (day) => {
  let calendarData = state.calendarData;
  for (let i = 0; i <calendarData.length; i++ ) {
    let items = calendarData[i];
    if (items.day == day) {
      if (items.currentPage == items.totalPage) {
        items.currentPage = items.totalPage
      } else {
        items.currentPage++
      }
    }
  }
}
</script>

<style scoped>
.view-btn>span{
  padding:10px 20px;
  background-color: rgb(248, 248, 248);
  border: 1px solid rgb(203, 203, 203);
}
.view-btn>span:first-child{
  border-radius: 5px 0 0 5px;
}
.view-btn>span:last-child{
  border-radius: 0 5px 5px 0;
}
.view-btn>span.active,.view-btn>span:hover{
  background-color: rgb(0, 122, 251, 0.9);
  color: #FFFFFF;
  border: 1px solid rgb(0, 122, 251);
}
.item-list {
  font-size: 0.75rem;
}
.item-page {
  font-size: 0.75rem;
}
</style>

ELPlusLanguageConfig.vue 组件

<!-- 给elementplus 单独设置国际化内容 -->
<template>
    <el-config-provider :locale="locale">
        <slot></slot>
    </el-config-provider>
</template>

<script setup>
import zhCn from 'element-plus/lib/locale/lang/zh-cn';
import { merge } from 'webpack-merge'; 
import {reactive,watch,ref} from 'vue'

const props = defineProps({
    local: { // 国际化
        type: Object,
        default() {
            return {}
        }
    }
})
const locale = ref({})
watch(()=>props.local,(newVal,oldVal)=>{
    locale.value = merge({}, zhCn, newVal)
},{
    immediate:true
})
</script>

<style scoped></style>

日历表头转换为周开头如下
useWeeks.js

/**
 * 日历切换,快捷时间切换改为结合dayjs实现
 * @param {*} valueFormat 
 * @returns 
 */
const useCalendar = (valueFormat = 'YYYY-MM') => {
    const local = {
        el: {
            datepicker: {
                weeks: {
                    fri: "周五",
                    mon: "周一",
                    sat: "周六",
                    sun: "周日",
                    thu: "周四",
                    tue: "周二",
                    wed: "周三",
                }
            }
        }
    }
    return local
}
export default useCalendar;

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

华秋约定您!7月11-13日慕尼黑上海电子展不见不散~

慕尼黑最新华秋展会攻略来啦 华秋携海量产品与方案 以及丰富的元器件产品线 即将亮相慕尼黑上海电子展 现场干货和福利不断 简直不要太精彩&#xff01; 敲黑板 划重点 华秋展位 时间&#xff1a;2023年7月11日-7月13日 地点&#xff1a;国际会展中心&#xff08;上海&…

IT-OT 安全融合是优化风险管理的关键

最新报告揭示了运营技术检测和响应方面的显着可见性差距。 全球网络安全运营商趋势科技宣布了一项新研究&#xff0c;显示企业安全运营中心 (SOC) 正在将其能力扩展到 OT 领域。 然而&#xff0c;重大的可见性和技能相关的挑战仍然造成障碍。 研究发现&#xff0c;一半的组织…

公共医疗数据库汇总:无需实验,高效论文撰写利器

一、引言 在医学研究领域&#xff0c;获取高质量的数据和文献资源是进行科学论文撰写的关键。随着信息技术的发展&#xff0c;以及公共医疗数据库的不断壮大和完善&#xff0c;研究人员可以轻松地获取大量的医学数据和文献信息&#xff0c;从而提高论文撰写的效率和质量。本文将…

基于Python的K-Means聚类算法的酒店客户价值分析(源码+数据+文档+CSV数据文件)

通过对传统的RFM客户价值研究模型进行分析&#xff0c;创新性的引入L&#xff08;信誉度&#xff09;指标到RFM模型中&#xff0c;形成RFML新型更适合酒店行业的客户价值研究模型。 一、技术介绍 &#xff08;1&#xff09;RFM 模型 RFM模型是提出的一种分析客户关系管理&…

C++旋转卡壳法求最小面积外接矩形

旋转卡壳基本概念介绍&#xff1a;(86条消息) 旋转卡壳详解_大学要有梦想的博客-CSDN博客 OpenCV里面有现成的计算最小面积外接矩形的方法&#xff0c;但是由于我装了好久也没装上opencv&#xff0c;最后还是决定自己实现。 求多边形最小面积外接矩形的基本思路是&#xff1a;…

loader 和 plugin

loader 是文件加载器&#xff0c;能够加载资源文件&#xff0c;并对这些文件进行一些处理&#xff0c;诸如编译、压缩等&#xff0c;最终一起打包到指定的文件中plugin 赋予了 webpack 各种灵活的功能&#xff0c;例如打包优化、资源管理、环境变量注入等&#xff0c;目的是解决…

数据分析:一文带你了解PowerBI技术

目录 一、PowerBI简介 二、Power BI 的组成部分 三、Power BI 如何匹配角色 四、下载 Power BI Desktop 五、登录到 Power BI 服务 六、Power BI的优势 6.1 发展潜力巨大&#xff0c;前景广阔 6.2 可连接的数据来源多&#xff0c;数据量大 6.3 软件更新频率高 6.4 可为…

飞凌嵌入式邀您共聚2023慕尼黑上海电子展

2023慕尼黑上海电子展&#xff08;electronica China&#xff09;将于7月11日~13日在国家会展中心&#xff08;上海&#xff09;盛大召开。本届展会将展示最新的电子技术与应用&#xff0c;涵盖了半导体、嵌入式系统、电源、电池、测试仪器、智能制造、电子设计自动化等众多领域…

【历史上的今天】7 月 7 日:C# 发布;Chrome OS 问世;《仙剑奇侠传》发行

整理 | 王启隆 透过「历史上的今天」&#xff0c;从过去看未来&#xff0c;从现在亦可以改变未来。 今天是 2023 年 7 月 7 日&#xff0c;在 1927 年的今天&#xff0c;互联网发展的早期创新者格伦卡勒&#xff08;Glen Culler&#xff09;出生&#xff1b;卡勒是 Culler-Fri…

如何洞察 .NET程序 非托管句柄泄露

一&#xff1a;背景 1. 讲故事 很多朋友可能会有疑问&#xff0c;C# 是一门托管语言&#xff0c;怎么可能会有非托管句柄泄露呢&#xff1f; 其实一旦 C# 程序与 C 语言交互之后&#xff0c;往往就会被后者拖入非托管泥潭&#xff0c;让我们这些调试者被迫探究 非托管领域问题…

第二章:安装VM+CentOS7安装+JDK及tomcat安装+安装mysql

目录 1. 安装VMWare 2. centos7安装 2.1 常见问题 3. 查看、设置IP地址 4. 关机与重启 5. 切换为国内源 6. Linux下的目录结构 7. JDK及tomcat安装 7.1 将压缩包上传到linux 7.2 安装JDK 7.3 安装Tomcat 8. 安装mysql 8.1 离线安装 8.2 在线安装 1. 安装VMWare 注意…

CentOS8.5 环境下部署 vsftpd

目录 前言安装vsftpd验证是否安装vsftpd安装vsftpd&#xff1a;操作vsftpd&#xff1a;vsftpd.conf配置创建用户添加端口安全组验证ftp搭建是否成功 前言 在物联网项目中&#xff0c;我们会经常使用到ftp服务器&#xff0c;今天我们就来实现一下centos8.5环境下部署vsftpd的搭建…

Buffer源码

介绍 首先 Buffer 是一个能存储基本数据类型的容器&#xff08;除了 Boolean 类型&#xff09;&#xff0c;从 java.nio 包的继承结构就能看出来。 Java中的Buffer类是一个抽象类。Buffer类提供了一种将数据存储在内存中的方式&#xff0c;并提供了一些操作数据的方法。Buffer…

原型模式:如何最快速地clone一个HashMap散列表?

我们还像学习建造者模式一样 思考 什么是原型模式&#xff1f;主要解决哪些问题&#xff1f; 如果对象的创建成本比较大&#xff0c;而同一个类的不同对象之间差别不大&#xff08;大部分字段都相同&#xff09;&#xff0c;在这种情况下&#xff0c;我们可以利用对已有对象…

5 类型转换

类型转换是变量与变量之间的&#xff0c;变量与常量之间是赋值。 5.1 自动类型转换 小转大。如下图所示&#xff0c;注意&#xff0c;byte不能自动转为char类型&#xff0c;因为类型不匹配&#xff0c;但是可以通过强转来转。 代码如下&#xff1a; byte a 10;int b a; 5.2…

测试流程实战(1)

目录&#xff1a; 测试流程梳理业务架构分析实战测试用例管理实战Bug 录入与管理实战如何写 Bug 报告编写 Bug 报告 1.测试流程梳理 2.业务架构分析实战 使用 plantuml 完成登录流程时序图plantuml 官网&#xff1a;使用简单的文字描述画UML图的开源工具。plantuml 在线绘图…

【HDC.Cloud 2023】华为开发者大会2023来了!这份PaaS参会指南请查收!

了不起的开发者们&#xff0c;我们来啦&#xff01; 7月7日&#xff0c;华为开发者大会2023 ( Cloud )将拉开帷幕 PaaS诚邀您参加这场不容错过的年度开发者盛会&#xff0c;让我们一起开启探索之旅。 我们将为开发者们提供PaaS生态资源工具、学习成长、分享交流、生态实践等…

Docker 安装Flowable-ui

查询镜像 docker search flowable-ui 拉取镜像 docker pull flowable/flowable-ui 使用默认数据库&#xff08;默认H2数据库&#xff09; docker run --name flowable-ui \ -p 8080:8080 \ -d --restartalways \ flowable/flowable-ui 使用MySQL数据库 docker run --name…

Windows环境Jmeter调优

在windows环境下搭建jmeter的压测实验环境&#xff0c;需要对操作系统默认的一些个参数进行设置&#xff0c;以提高并发能力。特别是作为压力机的时候。 Socket 编程时&#xff0c;单机最多可以建立多少个 TCP 连接&#xff0c;受到操作系统的影响。 Windows 下单机的TCP连接数…

simulink while/if/switch case

目录 while if Switch case while 循环设置100次 if Switch case 子模块可以用法和if一样