datePicker一个或多个日期组件,如何快捷选择多个日期(时间段)

elementUI的组件文档中没有详细说明type="dates"如何快捷选择一个时间段的日期,我们可以通过picker-options参数来设置快捷选择:

复制代码
<div class="block">
    <span class="demonstration">多个日期</span>
    <el-date-picker
      type="dates"
      v-model="value4"
      :picker-options="pickerOption"
      placeholder="选择一个或多个日期">
    </el-date-picker>
  </div>
</div>

通过设置变量pickerOption的值可设置快捷选择:

复制代码
pickerOption:{
	shortcuts:[
		text:'这半个月',
		onClick(picker){
			let end = new Date();
			let start = dateFormat(new Date(),'-');
			end.setTime(end.getTime() + 3600 * 1000 * 24 * 14);
			end = dateFormat(end,'-');
			let allDate = getAllDate(start,end);
			picker.$emit('pick', [...allDate]);
		}
	]
}

其中dateFormat方法是将日期格式化,getAllDate方法是获取开始和结束日期之间的全部日期,在data中定义:

复制代码
let dateFormat = (time,h='')=>{
	let ymd = '';
	let month = (time.getMonth() + 1 )>=10 ? (time.getMonth() + 1) : ('0' + (time.getMonth() +1));
	let day = time.getDate() >= 10? time.getDate() : ('0' + time.getDate());
	ymd += time.getFullYear() +h;
	ymd += month + h;
	ymd += day;
	return ymd;
}

let getAllDate=(start,end)=>{
	let allDateArr=[];
	let startArr = start.split('-');
	let endArr = end.split('-');
	let db = new Date();
	let db.setUTCFullYear(startArr[0[,startArr[1]-1,startArr[2]);
	let de = new Date();
	de.setUTCFullYear(endArr[0[,endArr[1]-1,endArr[2]);
	let unixDb = db.getTime();
	let unixDe = de.getTime();
	let stamp;
	const oneDay = 24*60*60*1000;
	for(stamp = inixDb;stamp<=unixDe;){
		allDateArr.push(dateFormat(new Date(parseInt(stamp)),'-'));
		stamp = stamp+oneDay;
	}
	return allDateArr;
}
相关推荐
薛定猫AI2 小时前
【深度解析】Gemma Chat 本地 AI 编程 Agent:Electron + MLX + 开源模型的离线 Vibe Coding 实战
javascript·人工智能·electron
全栈前端老曹2 小时前
【前端地图】多地图平台适配方案——高德、百度、腾讯、Google Maps SDK 差异对比、封装统一地图接口
前端·javascript·百度·dubbo·wgs84·gcj-02·bd09
笑虾2 小时前
Win10 修改注册表 让鼠标悬停PNG上时 tip 始终显示分辨率
开发语言·javascript·ecmascript
雾岛听风6913 小时前
JavaScript基础语法速查手册
开发语言·前端·javascript
用户2367829801683 小时前
从零实现 GIF 制作工具:LZW 压缩与 Median Cut 色彩量化
前端·javascript
棉猴3 小时前
Python海龟绘图之绘制文本
javascript·python·html·write·turtle·海龟绘图·输出文本
Highcharts.js4 小时前
线形比赛积分增长或竞赛图|Highcharts企业图表代码示列
开发语言·前端·javascript·折线图·highcharts·竞赛图
让学习成为一种生活方式4 小时前
大肠杆菌合成扑热息痛--对乙酰氨基酚--文献精读227
开发语言·前端·javascript
多秋浮沉度华年4 小时前
electron 初始使用记录
javascript·arcgis·electron
竹林8185 小时前
用 wagmi v2 + WebSocket 硬磕 NFT 上架失败:一个前端开发者踩过的实时状态同步坑
javascript·next.js