Element Plus el-calendar自定义使用

该代码示例展示了如何在Vue应用中结合ElementPlus的el-calendar组件,利用moment.js库解析时间戳并展示日历事件。组件包含了日历头的按钮操作,如切换年月,以及自定义的日期单元格模板,显示工作日程信息,包括重要性、工作班次和时间。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

结合element plus官网el-calendar的使用
parseTimestampToDate方法用的是 moment.js

<template>
	<el-calendar ref="calendar" v-model="value">
		<template #header="{ date }">
			<el-button-group>
				<el-button size="small" @click="selectDate('prev-year')">
					上一年
				</el-button>
				<el-button size="small" @click="selectDate('prev-month')">
					上个月
				</el-button>
			</el-button-group>
			<span>{{ date }}</span>
			<el-button-group>
				<el-button size="small" @click="selectDate('today')"
					>今天</el-button
				>
				<el-button size="small" @click="selectDate('next-month')">
					下个月
				</el-button>
				<el-button size="small" @click="selectDate('next-year')">
					下一年
				</el-button>
			</el-button-group>
		</template>
		<template #dateCell="{ data }">
			<div
				:class="
					currentShowDate(data.day) && currentShowDate(data.day).date
						? 'calendar-day work-day'
						: 'calendar-day'
				"
				:title="currentShowDate(data.day)?.content"
			>
				<p>
					{{ data.day.split("-").slice(1).join("-") }}
					{{ data.isSelected ? "✔️" : "" }}
				</p>
				<div
					v-if="currentShowDate(data.day)"
					:style="
						currentShowDate(data.day).type == 'important'
							? 'color: #f00'
							: ''
					"
				>
					<p>
						{{ currentShowDate(data.day).workShift }}
						{{ currentShowDate(data.day).workTime }}
					</p>
					<p class="content">{{ currentShowDate(data.day).content }}</p>
				</div>
			</div>
		</template>
	</el-calendar>
</template>

<script>
import { ref } from "vue";
import { parseTimestampToDate } from "@/utils/time.js";

export default {
	name: "clander",
	components: {},
	data() {
		return {
			value: new Date(), //当前选中的日期
			workCycleList: [
				{
					date: "2023-02-02",
					content:
						"生产100个配件,生产100个配件,生产100个配件,生产100个配件,生产100个配件,生产100个配件,生产100个配件",
					type: "important",
					workShift: "白班",
					workTime: "08:00 - 20:00",
				},
				{
					date: "2023-02-03",
					content: "清理机器",
					type: "common",
					workShift: "白班",
					workTime: "08:00 - 18:00",
				},
				{
					date: "2023-02-04",
					content: "日常生产配件",
					type: "common",
					workShift: "白班",
					workTime: "08:00 - 18:00",
				},
				{
					date: "2023-03-01",
					content: "日常生产配件",
					type: "common",
					workShift: "白班",
					workTime: "08:00 - 18:00",
				},
			],
		};
	},
	computed: {
		// 计算当前被选择的时间
		choosedDate() {
			const time = parseTimestampToDate(this.value, "MM/DD/YYYY  HH:mm");
			return time;
		},
	},
	mounted() {},
	methods: {
		currentShowDate(date) {
			let findWorkDay = null;
			findWorkDay = this.workCycleList.find((f) => f.date == date);
			return findWorkDay;
		},
	},
	setup() {
		const calendar = ref();
		const selectDate = (val) => {
			calendar.value.selectDate(val);
		};
		return { calendar, selectDate };
	},
};
</script>

<style lang="scss" scoped>
::v-deep .el-calendar-day {
	padding: 0;
}
.calendar-day {
	width: 100%;
	height: 100%;
	padding: 8px;
}
.work-day {
	background-color: #fef0f0;
}
.is-selected .work-day,
.work-day:hover {
	background-color: var(--el-calendar-selected-bg-color);
}
.content {
	overflow: hidden;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
}
</style>

效果如下:

 

### 修改 Element PlusEl-Calendar 组件的默认配置 为了实现将周一设为一周的第一天的功能,可以通过引入 `dayjs` 并设置其本地化选项来完成。具体操作如下: #### 1. 安装依赖库 如果尚未安装 `dayjs` 和对应的国际化包,则需要先通过 npm 或 yarn 进行安装: ```bash npm install dayjs dayjs/locale/zh-cn ``` #### 2. 配置代码 在项目入口文件或者使用该组件的页面中加入以下代码片段[^1]: ```javascript import dayjs from 'dayjs'; import 'dayjs/locale/zh-cn'; // 设置语言环境为中文 dayjs.locale('zh-cn'); ``` 上述代码的作用是更改日期对象的语言环境至中文,并调整星期显示顺序以适应中国习惯。 #### 3. 插槽兼容性处理 对于某些版本可能存在插槽名称大小写敏感问题的情况,需注意将模板中的 `#date-cell` 替换为大驼峰形式即 `#dateCell` 来确保功能正常运行[^2]。以下是完整的 HTML 结构实例展示如何定义自定义单元格内容的同时保持正确的周排列方式: ```vue <template> <el-calendar v-model="currentDate"> <!-- 自定义日期单元格 --> <template #dateCell="{ date }"> <div class="calendar-day">{{ getDayText(date) }}</div> </template> </el-calendar> </template> <script> export default { data() { return { currentDate: new Date(), }; }, methods: { getDayText(date) { const text = ['一', '二', '三', '四', '五', '六', '日'][date.getDay()]; return `${text}`; }, }, }; </script> ``` 以上脚本部分实现了动态获取每一天对应汉字表示的工作日名次逻辑以便于进一步美化界面布局设计需求扩展可能性无限广阔!
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值