需求分析
在实际项目中,表单里面的日期选择是常用的组件。Vant有提供日期组件,但是居然没有提供下拉形式的日期组件,不过该有的元件都有,就自己封装一个。
封装组件过程中我们要解决:
- 和表单的样式能兼容
- 错误提示
- 参数问题
- 事件机制
- 格式化
解决问题
就给新的组件取名为 VantFieldDate
。
期望使用的时候是这样的
<vant-field-date label="发布时间" v-model="formData.publishDate" type="datetime" :max-date="new Date()" />
具体实现,我贴上代码详细讲解。
<template> <div class="vant-field-date"> <van-cell :title="label" :class="{'readonly': readonly, 'placeholder' : text}" :is-link="!readonly" :required="required" @click="show"> <!-- 显示当前值,没有值显示提示文字 --> {{ text "$attrs.error" v-text="$attrs['error-message']" class="van-field__error-message" /> </van-cell> <!-- 用 actionsheet 来包裹弹出层日期控件 --> <van-actionsheet v-model="isShowPicker"> <!-- $attrs 可以把根节点的attr放到目标组件上,如此可以像使用 DatePicker 组件一样使用这个新组件 --> <van-datetime-picker v-bind="$attrs" :type="type" title="请选择日期" :min-date="minDate" :max-date="maxDate" @cancel="cancel" @confirm="confirm" /> </van-actionsheet> </div> </template> <script> export default { name: 'VantFieldDate', inheritAttrs: false, // https://cn.vuejs.org/v2/api/#inheritAttrs props: { value: { type: [Number, Date], default: undefined // 值不能是 null,DatePicker会报错 }, // Cell 显示的文字 label: { type: String, default: null }, // 必填的星号 required: { type: Boolean, default: false }, // 只读状态 readonly: { type: Boolean, default: false }, // 占位提示文字 placeholder: { type: String, default: '请选择' }, // 展示的格式化 format: { type: String, default: null } }, data() { return { selectedItem: null, isShowPicker: false } }, computed: { // 展示的格式化,时间提交的值是Date类型数据 formatFormula() { if(this.format){ return this.format } else if (this.type === 'date') { return 'yyyy-MM-dd' } else if (this.type === 'datetime') { return 'yyyy-MM-dd hh:mm' } else if (this.type === 'time') { return 'hh:mm' } else if (this.type === 'year-month') { return 'yyyy-MM' } }, text() { return this.value "text-align: center">以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com
暂无评论...
更新日志
2024年11月15日
2024年11月15日
- 文章.2004-被遗忘的时光【华博音乐】【WAV+CUE】
- 群星《青葱韶歌》原力计划·毕业季企划合辑[FLAC+分轨][661M]
- 群星《抖烧 DSD》抖音神曲 [WAV分轨][992M]
- 庾澄庆《哈林天堂》索尼音乐[WAV+CUE][1G]
- 英雄联盟全球总决赛多久打一次 全球总决赛举办频率介绍
- 第二届老头杯什么时候开始选人 第二届老头杯选人时间介绍
- 英雄联盟第二届老头杯什么时候开始 老头杯s2赛程时间队伍名单汇总
- AI赋能卓越显示技术共筑数字未来:三星显示器产品矩阵亮相2024进博会
- 技术剖析:天玑9400如何打造移动最强GPU和游戏体验?
- 顶级装备 实力登顶:三星显示器双十一焕新升级最后冲刺
- 陈影《绝色靓声》WAV+CUE
- 龚玥《禅是一枝花(6N纯银SQCD)》原抓WAV+CUE
- 刘德丽《寂寞在唱歌HQCD+A2HD5》[WAV+CUE]
- 萧亚轩《钻石糖》金牌大风[WAV+CUE][989M]
- 王菲《王菲精选-菲卖品》环球唱片SHM-SACD[ISO][1.9G]