el-date-picker picker-options属性中disabledDate设置时间的禁用和启用,并且支持到时分秒的禁用和启用

  • 默认picker-options 是配置的对象,如果代码中只存在一个开始时间或者一个结束时间,可以直接设置成对象进行配置

  • 我这里的应用场景是在表格中存在多个时间的配置项

    • 使用到了dayjs作为时间判断,也可以自行根据js来实现判断
    • 需要将picker-options 做成函数,应为表格每一行中都存在一个开始和结束时间,需要把每一行的开始和结束时间传递过去进行判断
    • 所以可以将picker-options当作函数,参数传递为对应需要进行处理开始和结束时间,返回值 picker-options 配置的参数
    • selectableRAnge 可以支持到时分秒的判断,例如结束时间的配置,需要拿到开始时间的时分秒,设置为自己时间可选范围的区间
  • 以下是代码部分
    *

    javascript 复制代码
    data() {
        return {
          // 结束时间的禁用
          endPickerOptions: function (item) {
            return {
              disabledDate: function (time) {
                if(!item.startTime) return false
                // 比较是否为同一天,如果组件中需要选择时分秒,则会出现开始时间和结束时间同一天无法选择的问题,需要加上判断,不需要时分秒可以去掉这行,开始和结束判断一样
                if(item.startTime && item.endTime && dayjs(item.startTime).format('YYYY-MM-DD') === dayjs(item.endTime).format('YYYY-MM-DD')) {
                  return false
                }
                return time.getTime() < item.startTime
              },
              selectableRange: (() => {
                if(!item.startTime) return [`00:00:00 - 23:59:59`]
                if(item.startTime) {
                  let date = new Date(item.startTime);
                  let hour = date.getHours();
                  let minute = date.getMinutes();
                  let second = date.getSeconds();
                  // 大于一天的话,时分秒可以随意选择
                  if(item.endTime - item.startTime > 3600 * 24) return [`00:00:00 - 23:59:59`]
                  return [`${hour}:${minute}:${second} - 23:59:59`]
                }
              })()
            }
          },
          // 开始时间的禁用
          startPickerOptions(item) {
            return {
              disabledDate: function (time) {
                if(!item.endTime) return false
                if(item.startTime && item.endTime && dayjs(item.startTime).format('YYYY-MM-DD') === dayjs(item.endTime).format('YYYY-MM-DD')) {
                  return false
                }
                return time.getTime() > item.endTime
              },
              selectableRange: (() => {
                if(!item.endTime) return [`00:00:00 - 23:59:59`]
                if(item.endTime) {
                  let date = new Date(item.endTime);
                  let hour = date.getHours();
                  let minute = date.getMinutes();
                  let second = date.getSeconds();
                  // 大于一天的话,时分秒可以随意选择
                  if(item.endTime - item.startTime > 3600 * 24) return [`00:00:00 - 23:59:59`]
                  return [`00:00:00 - ${hour}:${minute}:${second}`]
                }
              })()
            }
          },
        }
      },
相关推荐
云和数据.ChenGuang3 分钟前
vue中构建脚手架
前端·javascript·vue.js
渣哥6 分钟前
面试官最爱刁难:Spring 框架里到底用了多少经典设计模式?
javascript·后端·面试
q_191328469518 分钟前
基于RuoYi框架+Mysql的汽车进销存后台管理系统
数据库·vue.js·spring boot·mysql·汽车·个人开发·若依
朱昆鹏21 分钟前
如何通过sessionKey 登录 Claude
前端·javascript·人工智能
wdfk_prog21 分钟前
klist 迭代器初始化:klist_iter_init_node 与 klist_iter_init
java·前端·javascript
code_Bo1 小时前
基于vxe-table进行二次封装
前端·javascript·vue.js
闭着眼睛学算法1 小时前
【双机位A卷】华为OD笔试之【模拟】双机位A-新学校选址【Py/Java/C++/C/JS/Go六种语言】【欧弟算法】全网注释最详细分类最全的华子OD真题题解
java·c语言·javascript·c++·python·算法·华为od
晴殇i1 小时前
为什么现代 JavaScript 代码规范开始建议禁止使用 else ?
前端·javascript·前端框架
梦6502 小时前
axios请求
vue.js
源力祁老师2 小时前
OWL与VUE3 的高级组件通信全解析
前端·javascript·vue.js