欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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 內框輸入都變成只讀狀態(tài)。

//組件禁止組件里面的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');
        }
    })
}

這樣需求就實現(xiàn)了

到此這篇關于vue中el-date-picker限制選擇7天內&禁止內框選擇的文章就介紹到這了,更多相關el-date-picker限制選擇7天內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Vue調試工具vue-devtools的安裝與使用

    Vue調試工具vue-devtools的安裝與使用

    vue-devtools是專門調試vue項目的調試工具,安裝成功之后,右邊會出現(xiàn)一個vue,就可以在線可以調試vue了,下面這篇文章主要給大家介紹了關于Vue調試工具vue-devtools的安裝與使用的相關資料,需要的朋友可以參考下
    2022-07-07
  • axios攔截器工作方式及原理源碼解析

    axios攔截器工作方式及原理源碼解析

    這篇文章主要為大家介紹了axios攔截器工作原理源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-02-02
  • vue實現(xiàn)多個tab標簽頁的切換與關閉詳細代碼

    vue實現(xiàn)多個tab標簽頁的切換與關閉詳細代碼

    這篇文章主要給大家介紹了關于vue實現(xiàn)多個tab標簽頁的切換與關閉的相關資料,使用vue.js實現(xiàn)tab切換很簡單,文中通過代碼示例介紹的非常詳細,需要的朋友可以參考下
    2023-10-10
  • vue+iview實現(xiàn)文件上傳

    vue+iview實現(xiàn)文件上傳

    這篇文章主要為大家詳細介紹了vue+iview實現(xiàn)文件上傳,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • Vue3如何理解ref toRef和toRefs的區(qū)別

    Vue3如何理解ref toRef和toRefs的區(qū)別

    本文主要介紹了Vue3如何理解ref toRef和toRefs的區(qū)別,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • vue fetch中的.then()的正確使用方法

    vue fetch中的.then()的正確使用方法

    這篇文章主要介紹了vue fetch中的.then()的正確使用方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-04-04
  • 使用vue.js實現(xiàn)聯(lián)動效果的示例代碼

    使用vue.js實現(xiàn)聯(lián)動效果的示例代碼

    本篇文章主要介紹了使用vue.js實現(xiàn)聯(lián)動效果的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-01-01
  • 一文搞懂VueJs中customRef函數(shù)使用

    一文搞懂VueJs中customRef函數(shù)使用

    這篇文章主要為大家介紹了VueJs中customRef函數(shù)使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-04-04
  • Vue2打包部署后可動態(tài)修改后端接口地址的解決方法

    Vue2打包部署后可動態(tài)修改后端接口地址的解決方法

    本篇文章將介紹使用Vue2開發(fā)前后端分離項目時,前端打包部署后可動態(tài)修改后端接口地址的解決方法,文中通過圖文結合的方式介紹的非常詳細,需要的朋友可以參考下
    2024-07-07
  • vue頁面使用阿里oss上傳功能的實例(一)

    vue頁面使用阿里oss上傳功能的實例(一)

    本篇文章主要介紹了vue頁面使用阿里oss上傳功能的實例(一),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08

最新評論