elementUI,vue,前端判断时间是否有交集(重合)方法

分成三个部分

html

javascript 复制代码
<template>
	<el-form ref="Froms" :model="formData" :rules="rules" label-width="100px" size="small">
		<el-form-item label="日售卖区间:" prop="saleDayTime">
			<div style="border: 1px solid #DCDFE6; padding: 5px 0px 0px 5px; border-radius: 5px; margin-bottom: 5px;" v-if="this.formData.saleDayTime && this.formData.saleDayTime.length > 0">
				<el-tag v-for="(item,index) in formData.saleDayTime" :key="index" closable @close="handleClose(index)" style="margin-right: 5px; margin-bottom: 5px;">
					{{item}}
				</el-tag>
			</div>
			<el-time-picker v-model="tempTimeStart" :picker-options="{selectableRange: `00:00:00 -${tempTimeEnd ? tempTimeEnd : '23:59:59'}`}" placeholder="选择时间" value-format="HH:mm:ss" style="width: 120px;"></el-time-picker>
			<el-time-picker v-model="tempTimeEnd" :picker-options="{ selectableRange: `${tempTimeStart ? tempTimeStart : '00:00:00'} - 23:59:59`}"placeholder="选择时间" value-format="HH:mm:ss" style="width: 120px;"></el-time-picker>
			<el-button size="small" @click="addTime" type="primary" style="margin-left: 10px;">
				新增可用时间段
			</el-button>
		</el-form-item>
	</el-form>
</template>

※ 具体实现方法

javascript 复制代码
<script>
export default {
	// 判断时间是否有交集方法
	const checkSaleDay = (rule, value, callback) => {
		// console.log(value) // 时间格式: ['10:56:58-13:56:59']
		let arrOne = [];
		value.forEach((item) => {
			  let arr1 = item.split('-');
			  // 注:"24小时制"时间,将"时"、"分"、"秒",位上的时间以字符串形式进行拼接,拼接之后的数字时间越晚的数字会越大
		      let startTime = arr1[0].split(':')[0] + arr1[0].split(':')[1] + arr1[0].split(':')[2]; // "10"+"56"+"58", 以字符串形式拼接
		      let endTime = arr1[1].split(':')[0] + arr1[1].split(':')[1] + arr1[1].split(':')[2]; // "13"+"56"+"59", 以字符串形式拼接
		      arrOne.push({
	         	start: startTime,
	          	end: endTime
	        });
		});
		var len = arrOne.length;
		// console.log(arrOne)
		let satisfied = true;
		for (var i = 0; i < len; i++) {
			for (var j = i + 1; j < len; j++) {
				let start1 = arrOne[i].start;
		        let start2 = arrOne[j].start;
		        let end1 = arrOne[i].end;
		        let end2 = arrOne[j].end;
		        if (start1 < start2 && start2 < end1) { // 例:start1=3,end1=6;start2=5,end2=10
		           satisfied = false;
		        } else if (start1 > start2 && end2 > start1) { // 例:start1=3,end1=6;start2=2,end2=5
	               satisfied = false;
	            } else if (start1 > start2 && end1 < end2) { // 例:start1=3,end1=6;start2=2,end2=10
	               satisfied = false;
	           }  else if (start1 < start2 && end1 > end2) { // 例:start1=3,end1=6;start2=4,end2=5
	               satisfied = false;
	           }
			}
		}
		if (satisfied) {
	        callback();
	    } else {
	        callback(new Error('售卖区间产生存在交集,请确认后重选'));
	    }
	}
	data() {
		return{
			tempTimeStart: '', // 所选开始时间回显
      		tempTimeEnd: '', // 所选结束时间回显
			formData:{
				saleDayTime: [],
			},
			rules: {
				saleDayTime: [{
		          required: true,
		          message: '请选择日售卖区间',
		          trigger: 'change'
		        },{
		          required: true,
		          validator: checkSaleDay,
		          trigger: 'change'
		        }]
			}
		}
	},
}
<script>

methods

javascript 复制代码
<script>
	export default {
		methods:{
			// 删除所选时间
			handleClose(index) {
		       this.formData.saleDayTime.splice(index, 1);
		    },
			// 新增可用时间段
			addTime() {
			   if (!this.tempTimeStart || !this.tempTimeEnd) {
			      return;
			   }
			   if (!this.formData.saleDayTime) {
			      this.formData.saleDayTime = [];
			   }
			   // 把选择的时间加入数组里
			   this.formData.saleDayTime.push(this.tempTimeStart + '-' + this.tempTimeEnd);
			   // 加入成功后清空回显值
			   this.tempTimeStart = '';
			   this.tempTimeEnd = '';
			}
		}
	}
<script>

帮助理解逻辑图:

简化:由上面的逻辑反推[1](#简化:由上面的逻辑反推1)

javascript 复制代码
<script>
export default {
	// 判断时间是否有交集方法
	const checkSaleDay = (rule, value, callback) => {
		// console.log(value) // 时间格式: ['10:56:58-13:56:59']
		let arrOne = [];
		value.forEach((item) => {
			  let arr1 = item.split('-');
			  // 注:"24小时制"时间,将"时"、"分"、"秒",位上的时间以字符串形式进行拼接,拼接之后的数字时间越晚的数字会越大
		      let startTime = arr1[0].split(':')[0] + arr1[0].split(':')[1] + arr1[0].split(':')[2]; // "10"+"56"+"58", 以字符串形式拼接
		      let endTime = arr1[1].split(':')[0] + arr1[1].split(':')[1] + arr1[1].split(':')[2]; // "13"+"56"+"59", 以字符串形式拼接
		      arrOne.push({
	         	start: startTime,
	          	end: endTime
	        });
		});
		var len = arrOne.length;
		// console.log(arrOne)
		let satisfied = false; // 注意这时候这里的变量值为false了哦
		for (var i = 0; i < len; i++) {
			for (var j = i + 1; j < len; j++) {
				let start1 = arrOne[i].start;
		        let start2 = arrOne[j].start;
		        let end1 = arrOne[i].end;
		        let end2 = arrOne[j].end;
		        if (end1 < start2 || start1 < end2) { // 例:start1=3,end1=6;start2=7,end2=10;start1=3,end1=6;start2=1,end2=2
		           satisfied = true;
		        }
			}
		}
		if (satisfied) {
	        callback();
	    } else {
	        callback(new Error('售卖区间产生存在交集,请确认后重选'));
	    }
	}
}
<script>

  1. 反推思维逻辑图:
    ↩︎
相关推荐
Spider_Man几秒前
面试官:你能手写 bind 吗?——JS this 全家桶趣味深度剖析
前端·javascript·面试
ikonan1 分钟前
译:不要过度优化你的优化
前端·javascript·react.js
ze_juejin1 分钟前
浏览器缓存机制与注意事项总结
前端
复苏季风2 分钟前
vite里把markdown文件渲染成vue组件
vue.js·markdown
山西第一大怨种3 分钟前
我的浏览器下雨了进水了
前端·webgl
streaker3034 分钟前
Vue3 + TSX 封装 el-table:还原 Antd 风格的 Columns 配置
vue.js·element
何贤4 分钟前
😲我写出了 Threejs 版城市天际线?!(官推转发🥳+ 源码分享🚀)
前端·开源·three.js
前端老鹰4 分钟前
JavaScript Array.prototype.at ():数组任意位置取值的新姿势
前端·javascript
autumnTop11 分钟前
为什么访问不了同事的服务器或者ping不通地址了?
前端·后端·程序员
weixin_4433533133 分钟前
小红书帖子评论的nodejs爬虫脚本
前端·爬虫