el-time-picker选择时分秒并且根据总秒数禁用不可选

效果图

dom结构---总秒数188

javascript 复制代码
<div class="popover">
	<div style="display: flex;align-items: center;">时间点: 
		<el-time-picker
			value-format="mm:ss"
			format="mm:ss"
			:picker-options="{
			selectableRange: '00:00:00 - 00:59:59'
			}"
			:disabled-hours="disabledHours"
			:disabled-minutes="disabledMinutes"
			:disabled-seconds="disabledSeconds"
			style="width: 100px;margin-left: 8px;"
			v-model="state.selectTime.time"
			popper-class="noneMinute"
			placeholder="请选择"
		/>
		<el-button @click="closeImage" style="margin-left: 8px;" size="small">取消</el-button>
		<el-button @click="sureBtn" style="margin-left: 2px;" type="primary" size="small">确定</el-button>
	</div>
</div>

事件

javascript 复制代码
const state = reactive({
	selectTime: {
		time: '00:00' as any
	},
	meta_data_duration: 188 as any,
	minutes: null as any
});
// 数据处理
const makeRange = (start: number, end: number) => {
  const result: number[] = []
  for (let i = start; i <= end; i++) {
    result.push(i)
  }
  return result
}
// 小时
const disabledHours = () => {
  	return makeRange(0, 23)
}
// 分钟
const disabledMinutes = () => {
	const val = state.meta_data_duration
	const min = parseInt(val % 3600 / 60)
	state.minutes = min
	return makeRange(min, 59)
}
// 秒数
const disabledSeconds = (hour: number, minute: number) => {
	const val = state.meta_data_duration
	const sec = parseInt(val % 3600 % 60)
	if (state.minutes === minute + 1) {
		return makeRange(sec, 59)
	}
}

只显示分秒,隐藏小时,

javascript 复制代码
// 作用全局,为避免影响到其他页面样式,所以外层写一个单独的类名用于区分
<style lang="scss">
// 隐藏小时的代码
.noneMinute {
	.el-scrollbar:nth-of-type(1) {
		display: none !important;
	}
	//调整样式
	.el-time-spinner {
		width: 150%;
		white-space: nowrap;
	}
}
</style>
相关推荐
恋猫de小郭1 小时前
Flutter 正在计划提供 Packaged AI Assets 的支持,让你的包/插件可以更好被 AI 理解和选择
android·前端·flutter
小小前端--可笑可笑1 小时前
Vue / React 单页应用刷新 /login 无法访问问题分析
运维·前端·javascript·vue.js·nginx·react.js
小林敲代码77882 小时前
记一次 Vue 项目首屏优化:从 7.1s 到 0.9s,深挖 Gzip 的力量
前端·javascript·vue.js
前端大卫2 小时前
写给年轻程序员的几点小建议
前端
Highcharts.js2 小时前
什么是向量图表?如何用 Highcharts 快速创建一个笛卡尔坐标图/矢量图?
javascript·开发文档·highcharts·图表开发·向量图·矢量图表·笛卡尔坐标图
NEXT063 小时前
React 闭包陷阱深度解析:从词法作用域到快照渲染
前端·react.js·面试
脱离语言3 小时前
Jeecg3.8.2 前端经验汇总
开发语言·前端·javascript
NEXT063 小时前
useMemo 与 useCallback 的原理与最佳实践
前端·javascript·react.js
小爱丨同学3 小时前
React-Context用法汇总 +注意点
前端·javascript·react.js
徐同保4 小时前
python如何手动抛出异常
java·前端·python