VantUI时间选择器

​ 距离我上一次博客都距离五个多月了,证明我这五个月没有好好学习,自我反省下。

​ 这次写这个博客,是我工作中遇到的问题,项目是做一个h5移动端的商城。之前没用过VantUI,拿到需要用到时间选择器的时候也是捉摸了一会。

​ 大概需求是,点击弹出时间选择器,并显示时间到页面上。

​ 一开始看文档的时候也没太仔细,没看到前面的一句话时间选择组件通常与弹出层组件配合使用。如果直接按需导入,时间选择器会直接出现在页面上。

引入

​ 这里采用的按需导入。

import { Popup } from 'vant';
import { DatetimePicker } from 'vant';

Vue.use(Popup)
Vue.use(DatetimePicker);

主要代码

  1. 需求主要是实现年月日的选择,type="date",由于页面时间选择器较多(需求有四个)所以我只写了一个弹出层,选择器全部放弹出层里,通过 v-if 控制显示与隐藏

  2. 开始时间不能高于当前日期,:max-date="currentTime"

  3. 结束时间不能低于开始日期,:min-date="startTime"

  4. cancelconfirm 为 vantUI 时间选择器提供的事件,点击取消或确认按钮触发事件,其中 confirm 有个回调参数 value 为当前选择的时间

  5. 将弹出层组件套在时间选择器的组件外面,进行组合使用,需要手动在取消、确认按钮上加事件隐藏弹出层

  6. formatter 调用的官方文档的formatter方法,会将选项文字进行格式化处理,如下图所示,左边是调用后的效果

    ![1561472599881.png](https://upload-images.jianshu.io/upload_images/16048198-4664af678baf8eec.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

我这里只放了一部分代码

<template>
    <div>
        <!-- 按钮区域 -->
        <div>
            <span ref="termStart" @click="showDatePicker('termStart')">开始时间</span>
            <span ref="termEnd" @click="showDatePicker('termEnd')">结束时间</span>
        </div>
        <!-- 弹出层 -->
        <van-popup v-model="isPopShow" position="bottom">
            <!-- 开始时间 -->
            <van-datetime-picker
                @cancel="cancelPicker"
                @confirm="confirmPicker"
                v-if="datePicker == 'startTime'"
                v-model="startTime"
                type="date"
                :formatter="formatter"
                :max-date="currentTime"
             />
            <!-- 结束时间 -->
            <van-datetime-picker
                @cancel="cancelPicker"
                @confirm="confirmPicker"
                v-if="datePicker == 'endTime'"
                v-model="endTime"
                type="date"
                :formatter="formatter"
                :min-date="startTime"
             />
        </van-popup>
    </div>
</template>
<script>
export default {
    data() {
        return {
            currentTime: new Date(), // 开始时间不能超过当前时间
            startTime: new Date(), // 开始时间
            endTime: new Date(), // 结束时间
            datePicker: '', // 用于判断哪个选择器的显示与隐藏
            isPopShow: false, // 弹出层隐藏与显示
        }
    },
    methods: {
        showDatePicker(picker) { //弹出层并显示时间选择器
            this.isPopShow = true;
            this.datePicker = picker;
        },
        cancelPicker() { // 选择器取消按钮点击事件
            this.isPopShow = false;
            this.datePicker = "";
        },
        confirmPicker(value) {// 确定按钮,时间格式化并显示在页面上
            var date = value;
            var m = date.getMonth() + 1;
            var d = date.getDate();
            if (m >= 1 && m <= 9) {
                m = "0" + m;
            }
            if (d >= 0 && d <= 9) {
                d = "0" + d;
            }
            var timer = date.getFullYear() + "-" + m + "-" + d
            this.$refs[this.datePicker].innerHTML = timer;
            this.isPopShow = false;
            this.datePicker = "";
        },
        formatter(type, value) {// 格式化选择器日期
            if (type === "year") {
                return `${value}年`;
            } else if (type === "month") {
                return `${value}月`;
            }
            return value;
        },
    }
    
}
</script>

展示效果

按钮

1561472584970.png

时间选择器

1561472599881.png

显示时间

1561472614115.png

总结

​ 表示自己还是个小菜鸟,欢迎各路大神指点和探讨。


timg.jpg
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,793评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,567评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,342评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,825评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,814评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,680评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,033评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,687评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,175评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,668评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,775评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,419评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,020评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,206评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,092评论 2 351
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,510评论 2 343

推荐阅读更多精彩内容