el-date-picker,日期时间范围选择器默认只能选择7天

elementplus组件

html 复制代码
<el-date-picker
	style="width: 100%"
	v-model="dayTime"
	type="datetimerange"
	:start-placeholder="$t('public.startTime')"
	:end-placeholder="$t('public.endTime')"
	@change="changeEndDate"
	@calendar-change="calendarChange"
	format="YYYY/MM/DD HH:mm:ss"
	:disabled-date="disabledDateOption"
	:clearable="false"
/>

dayTime:用户选择的时间范围数组

disableDate:根据选择的第一个时间点来判断用户选择的前后7天的时间结束点

TypeScript 复制代码
const dayTime = ref<Array<string>>([]);
const disableDate = ref<string>("");

calendarChange事件,用户选择完第二个时间值后把之前用来判断的disableDate置空

TypeScript 复制代码
const calendarChange = (time: any[]) => {
	disableDate.value = time[0];
	if (time[1]) {
		disableDate.value = "";
	}
};

disabledDateOption:判断禁用的时间范围

TypeScript 复制代码
const disabledDateOption = (time: any) => {
	if (disableDate.value) {
		disableDate.value = moment(new Date(disableDate.value)).format("YYYY-MM-DD HH:mm:ss");
		return (
			moment(time).isAfter(moment(disableDate.value).add(7, "days"), "days") ||
			moment(time).isBefore(moment(disableDate.value).subtract(7, "days"), "days") ||
			moment().isBefore(time, "days")
		);
	} else {
		return moment().isBefore(time, "days");
	}
};
相关推荐
肥肠可耐的西西公主11 分钟前
前端(AJAX)学习笔记(CLASS 2):图书管理案例以及图片上传
前端·笔记·学习
大胖丫12 分钟前
vue 学习-vite api.js
开发语言·前端·javascript
孙桂月13 分钟前
ES6相关操作(2)
前端·javascript·es6
陈浩源同学14 分钟前
学习 TypeScript 栈和队列数据结构
前端·算法
我这一生如履薄冰~16 分钟前
简单封装一个websocket构造函数
前端·javascript·websocket
fangcaojushi16 分钟前
解决webpack5.54打包图片及图标的问题
前端·vue.js
海盗强16 分钟前
Webpack打包优化
前端·webpack·node.js
星之卡比*18 分钟前
前端面试题---vite和webpack的区别
前端·面试
^^为欢几何^^23 分钟前
npm、pnpm和yarn有什么区别
前端·npm·node.js
前端菜鸟日常30 分钟前
vue2和vue3的按需引入的详细对比通俗易懂
javascript·vue.js·ecmascript