vue中el-date-picker限制选择7天内&禁止内框选择

 更新时间:2023年12月20日 11:40:20   作者:QQ帝国  
项目中需要选择时间范围,并且只能选择当前日期之后的七天,本文就来介绍了vue中el-date-picker限制选择7天内&禁止内框选择,具有一定的参考价值,感兴趣的可以了解一下

 需求:elementPlus时间段选择框需要满足:①最多选7天时间。②不能手动输入。

<el-date-picker 
    v-model="timeArrange" 
    @focus="timeEditable" 
    :editable="false" 
    type="datetimerange" 
    range-separator="至" start-placeholder="开始日期" 
    value-format="YYYY-MM-DD HH:mm:ss" 
    :disabled-date="disabledDateFn" 
    @calendar-Change="calendarChange" 
    end-placeholder="结束日期" 
    style="width: 100%" 
/>

①、限制最多选7天时间问题

加属性 :disabled-date="disabledDateFn" 和 @calendar-Change="calendarChange"

const disabledDateFn = (time: any) => {
    // 如何选择了一个日期
    if (choiceDate.value) {
        // 7天的时间戳
        const one = 6 * 24 * 3600 * 1000;
        // 当前日期 - one = 7天之前
        const minTime = choiceDate.value - one;
        // 当前日期 + one = 7天之后
        const maxTime = choiceDate.value + one;
        return (
            time.getTime() < minTime ||
            time.getTime() > maxTime
            // 限制不能选择今天及以后
            // || time.getTime() + 1 * 24 * 3600 * 1000 > Date.now()
        );
    } else {
        // 如果没有选择日期,就要限制不能选择今天及以后
        // return time.getTime() + 1 * 24 * 3600 * 1000 > Date.now();
    }
}

const calendarChange = (obj: any) => {
    const minDate = obj[0]
    const maxDate = obj[1]
    // 把选择的第一个日期赋值给一个变量。
    choiceDate.value = minDate.getTime();
    // 如何你选择了两个日期了,就把那个变量置空
    if (maxDate) choiceDate.value = null;
}

效果如下: 

②限制手动输入问题

这里有内外两个输入框需要限制

外部 的可以直接用属性 :editable="false" 限制

内部 的这里需要通过 @focus="timeEditable" 把 input 内框输入都变成只读状态。

//组件禁止组件里面的input输入值
const timeEditable = ()=>{
    nextTick(() => {
        let els = document.querySelectorAll('.el-input__wrapper input');
        for (var i = 0; i <= els.length - 1; i++) {
            els[i].setAttribute('readonly', 'readonly');
        }
    })
}

这样需求就实现了

到此这篇关于vue中el-date-picker限制选择7天内&禁止内框选择的文章就介绍到这了,更多相关el-date-picker限制选择7天内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue项目点击元素后如何改变样式

    vue项目点击元素后如何改变样式

    这篇文章主要介绍了vue项目点击元素后如何改变样式问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • vue上传文件formData入参为空,接口请求500的解决

    vue上传文件formData入参为空,接口请求500的解决

    这篇文章主要介绍了vue上传文件formData入参为空,接口请求500的解决,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-06-06
  • vue3.0 CLI - 2.4 - 新组件 Forms.vue 中学习表单

    vue3.0 CLI - 2.4 - 新组件 Forms.vue 中学习表单

    这篇文章主要介绍了vue3.0 CLI - 2.4 - 新组件 Forms.vue 中学习表单的相关知识,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值 ,需要的朋友可以参考下
    2018-09-09
  • Vue中使用的EventBus有生命周期

    Vue中使用的EventBus有生命周期

    这篇文章主要介绍了Vue中使用的EventBus有生命周期的相关知识,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-07-07
  • vue中swiper开启loop后,点击事件不响应的解决方案

    vue中swiper开启loop后,点击事件不响应的解决方案

    这篇文章主要介绍了vue中swiper开启loop后,点击事件不响应的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-09-09
  • 如何在vue项目中使用UEditor--plus

    如何在vue项目中使用UEditor--plus

    UEditor是由百度web前端研发部开发的所见即所得的开源富文本编辑器,这篇文章主要介绍了如何在vue项目中使用UEditor--plus ,需要的朋友可以参考下
    2022-08-08
  • 在Vue中创建可重用的 Transition的方法

    在Vue中创建可重用的 Transition的方法

    这篇文章主要介绍了在Vue中创建可重用的 Transition,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-06-06
  • 详解Vue注册组件的方法

    详解Vue注册组件的方法

    Vue注册组件有这几种,分别是全局注册、局部注册、在模块系统中注册,这篇文章主要介绍了Vue注册组件的方法,需要的朋友可以参考下
    2022-08-08
  • vue实现进入某个页面后替换地址栏路径的操作方法

    vue实现进入某个页面后替换地址栏路径的操作方法

    vue页面在实际开发中,经常会遇到改变url参数,重新加载页面数据的需求,但是只改变页面url并不会触发组件的生命周期,这就需要用其他方法来实现了,本文重点介绍vue实现进入某个页面后替换地址栏路径的操作方法,感兴趣的朋友跟随小编一起看看吧
    2024-04-04
  • 解读Vue-loader的相关知识

    解读Vue-loader的相关知识

    这篇文章主要介绍了解读Vue-loader的相关知识,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-03-03

最新评论