Element Plus el-calendar自定义使用

结合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>

效果如下:

 

  • 2
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Element Plus 的 el-table-v2 组件支持自定义多级表头,可以通过 el-table-column 的 children 属性来实现。具体步骤如下: 1. 在 el-table-column 中设置 prop 和 label 属性,用于显示表头名称和对应的数据字段。 2. 如果需要设置多级表头,可以在 el-table-column 中设置 children 属性,并在其中嵌套新的 el-table-column 组件,重复步骤1。 3. 如果需要合并表头单元格,可以在 el-table-column 中设置 rowspan 和 colspan 属性。 4. 如果需要自定义表头样式,可以在 el-table-column 中设置 headerStyle 属性。 下面是一个示例代码,展示了如何使用 el-table-v2 自定义多级表头: ``` <template> <el-table :data="tableData"> <el-table-column prop="name" label="姓名"></el-table-column> <el-table-column label="成绩"> <el-table-column prop="math" label="数学"></el-table-column> <el-table-column prop="english" label="英语"></el-table-column> <el-table-column prop="chinese" label="语文"></el-table-column> </el-table-column> <el-table-column prop="total" label="总分" rowspan="2"></el-table-column> </el-table> </template> <script> import { ref } from "vue"; import { ElTable, ElTableColumn } from "element-plus"; export default { components: { ElTable, ElTableColumn, }, setup() { const tableData = ref([ { name: "张三", math: 80, english: 90, chinese: 85, total: 255 }, { name: "李四", math: 75, english: 85, chinese: 90, total: 250 }, ]); return { tableData, }; }, }; </script> ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值