第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定

基于vuejs-datepicker 二次封裝的 VUE 時(shí)間區(qū)間選擇器組件

標(biāo)簽:
Node.js Html5 Vue.js

https://img1.sycdn.imooc.com//5bac4b240001343b03820314.jpg

需求:

1.当前时间高亮。

2.起始时间不能大于终止时间(日期范围禁用)。

3.带时间清除。

4.实现国际化。

第一步:

查看官方文档vuejs-datepicker,安装

npm install vuejs-datepicker --save

第二步:

在需要封装组件里引用。(不细说,直接上封装的组件源码)

<template>
    <div>
        <datepicker @opened="openView"
                    @selected="disableTo"
                    v-model="startDate"
                    :disabledDates="minDate"
                    :clear-button = "true"
                    :highlighted="highlightedFn"
                    :format="customFormatter"
                    :language="languages[lang]"
                    :placeholder="$t('START_TIME')"></datepicker>
        <i class="el-icon-minus"></i>
        <datepicker @opened="openView"
                    @selected="disableFrom"
                    v-model="endDate"
                    :disabledDates="maxDate"
                    :clear-button = "true"
                    :highlighted="highlightedFn"
                    :format="customFormatter"
                    :language="languages[lang]"
                    :placeholder="$t('END_TIME')"></datepicker>
    </div>
</template>

<script>
import Datepicker from 'vuejs-datepicker'
import {en, ja, zh} from 'vuejs-datepicker/dist/locale'
export default {
    name: "vo-date-range",
    components:{ Datepicker },
    data:()=>({
        highlightedFn: {
            customPredictor(date) {
                if (date.getDate() === (new Date()).getDate()) {
                    return true;
                }
            }
        },
        languages:{en: en,zh: zh,jp: ja},
        lang:'',
        startDate:'',
        endDate:'',
        minDate:{},
        maxDate:{},
        html:''
    }),
    methods: {
    
          //自定义时间格式
            customFormatter(date) {
                return moment(date).format('YYYY-MM-DD')
            },
            
            //在打开时间控件的时候,获取localStorage中的语言。
            //这样做的目的是为了与父级语言切换同步
        openView(){
            this.lang = JSON.parse(localStorage.getItem('locale')).type
        },

        //设置disable时间区间
        disableTo(date) {
                this.maxDate = {
                    to:date,
               from : null
            }
            this.$emit('getDate',{startDate:date,endDate:this.endDate});
        },
        disableFrom(date) {
                this.minDate = {
                    to:null,
               from: date
                }
            this.$emit('getDate',{startDate:this.startDate,endDate:date});
        }
    }
}
</script>

在需要的页面引用:

<template>
<div class="input-lgx-box">
    <label>{{ $t("CREATED_TIME") }}</label>
    <voDateRange @getDate="getDate"></voDateRange>
</div>
</template>
<script>
import voDateRange from '@/components/voDateRange.vue'

export default {
    name: "order-list",
    components:{ voDateRange},
    methods:{
        getDate(obj){
            console.log(obj)
        }
    }
}
</script>


點(diǎn)擊查看更多內(nèi)容
5人點(diǎn)贊

若覺得本文不錯(cuò),就分享一下吧!

評(píng)論

作者其他優(yōu)質(zhì)文章

正在加載中
感謝您的支持,我會(huì)繼續(xù)努力的~
掃碼打賞,你說多少就多少
贊賞金額會(huì)直接到老師賬戶
支付方式
打開微信掃一掃,即可進(jìn)行掃碼打賞哦
今天注冊(cè)有機(jī)會(huì)得

100積分直接送

付費(fèi)專欄免費(fèi)學(xué)

大額優(yōu)惠券免費(fèi)領(lǐng)

立即參與 放棄機(jī)會(huì)
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)

舉報(bào)

0/150
提交
取消