news 2026/6/10 12:18:42

对于vant picker和datetime-picker二次封装分享

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
对于vant picker和datetime-picker二次封装分享

文章目录

    • 概要
    • 前置知识点
    • 直接上组件代码
    • datetime-picker组件代码

概要

我们日常开发中使用vant实现下拉列表,很多时候绑定的都是对象数组,折腾一下也能搞,但是每次都会写一大堆代码

//template<van-field readonly clickable name="picker":value="searchPopup.warehouseNumber.description"label="仓库"placeholder="点击选择"@click="searchPopup.warehouseNumber.show = true"/><van-popup v-model="searchPopup.warehouseNumber.show"position="bottom"><van-picker show-toolbar:columns="warehouses"value-key="Description"text-key="Code"@confirm="searchPopup.warehouseNumber.onConfirm"@cancel="searchPopup.warehouseNumber.show = false"/></van-popup>//datasearchPopup:{show:false,warehouseNumber:{show:false,description:'',onConfirm:(value)=>{this.searchPopup.warehouseNumber.description=value.Descriptionthis.searchInfo.WarehouseNumber=value.Codethis.searchPopup.warehouseNumber.show=false}}},searchInfo:{WarehouseNumber:''}

这样一大坨重复写就很不爽啊,所以打算抽离出组件,最后我要的用法就是

<MyPicker label="仓库":columns="warehouses"valueKey="Description"textKey="Code"v-model="searchInfo.WarehouseNumber"/>

这里需要说明下我们的columns的结构

[{Code:0,Description:'仓库1'},{Code:1,Description:'仓库2'}]

前置知识点

有个前置知识点需要解释下,不然有的朋友可能代码会看的有点懵
vue2里面有个语法糖,就是v-model等价于:1、组件有个名为value的props,然后v-model变量就绑定到这个value的props上的;2、组件内部抛出的一个事件名为input的事件,事件的值就绑定到v-model这个变量上了

直接上组件代码

<template><div><van-field readonly clickable:value="displayText":label="label"placeholder="点击选择"@click="show = true"/><van-popup v-model="show"position="bottom"><van-picker show-toolbar:columns="columns":value-key="valueKey":text-key="textKey"@confirm="onConfirmHandler"@cancel="show = false"/></van-popup></div></template><script>exportdefault{props:['label','columns','valueKey','textKey','value'],data(){return{show:false}},mounted(){},computed:{displayText(){if(!this.value||!this.columns.length)return''constitem=this.columns.find(item=>item[this.textKey]===this.value)returnitem?item[this.valueKey]:''}},methods:{onConfirmHandler(value){this.$emit('input',value[this.textKey])this.show=false}},}</script><style scoped></style>

datetime-picker组件代码

<template><div><van-field readonly clickable:value="displayValue":label="label"placeholder="点击选择"@click="show = true"/><van-popup v-model="show"position="bottom"><van-datetime-picker show-toolbar v-model="internalValue"type="datetime"title="选择时间"@cancel="show = false"@confirm="onConfirmHandler"/></van-popup></div></template><script>import{formatDateTime}from'@/utils/Common'exportdefault{props:['label','value'],data(){return{show:false,internalValue:this.value||newDate()}},mounted(){},computed:{displayValue(){returnthis.value?formatDateTime(this.value):''}},methods:{onConfirmHandler(value){this.$emit('input',formatDateTime(value))this.show=false}},}</script><style scoped></style>

那个格式化时间就安装moment就行

使用示例

<MyDatetimePicker label="创建时间"v-model="createDatetime"/>
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/8 22:19:48

Python基于Vue的二次元服装租售系统 租赁和销售双流程django flask pycharm

这里写目录标题项目介绍项目展示详细视频演示技术栈文章下方名片联系我即可~解决的思路开发技术介绍性能/安全/负载方面python语言Django框架介绍技术路线关键代码详细视频演示收藏关注不迷路&#xff01;&#xff01;需要的小伙伴可以发链接或者截图给我 项目介绍 近年来&am…

作者头像 李华
网站建设 2026/6/6 0:57:45

机器学习毕业设计全流程难点总结:从数据到模型、答辩必踩坑与解决方案

机器学习方向毕业设计是计算机、人工智能、数据科学等专业的热门选择&#xff0c;但数据缺失、模型选型不当、实验不规范、结果不可复现、论文逻辑混乱等问题&#xff0c;成为多数本科生毕设失败或低分的核心原因。本文结合历年毕设指导经验&#xff0c;系统梳理机器学习毕设全…

作者头像 李华
网站建设 2026/5/29 9:25:58

Linux 编辑器入门:nano 与 vim 的区别与选择指南

在学习 Linux 或进行服务器开发时&#xff0c;我们经常会遇到两个命令&#xff1a;nano a.txt vim a.txt很多初学者会疑惑&#xff1a; 它们都是打开文件编辑吗&#xff1f;有什么区别&#xff1f;我该用哪个&#xff1f;本文一次性讲清楚 nano 与 vim 的定位、区别、使用场景。…

作者头像 李华
网站建设 2026/6/10 9:38:36

连续两年制霸春节档 王丹妮《夜王》今日定档大年初四

继2025年主演的贺岁动作喜剧《临时决斗》夺得香港电影春节档票房冠军后&#xff0c;演员王丹妮再次以强势姿态回归农历新年。由《毒舌律师》金牌班底打造&#xff0c;黄子华、郑秀文领衔主演的爆笑粤语喜剧《夜王》于今日正式官宣&#xff0c;将于大年初四&#xff08;2月20日&…

作者头像 李华
网站建设 2026/5/31 1:10:41

Python基于Vue的婚纱摄影预订管理系统 django flask pycharm

这里写目录标题项目介绍项目展示详细视频演示技术栈文章下方名片联系我即可~解决的思路开发技术介绍性能/安全/负载方面python语言Django框架介绍技术路线关键代码详细视频演示收藏关注不迷路&#xff01;&#xff01;需要的小伙伴可以发链接或者截图给我 项目介绍 随着我国经…

作者头像 李华
网站建设 2026/6/10 11:12:38

基于对抗领域自适应的风电机组故障诊断方法研究

✅ 博主简介&#xff1a;擅长数据搜集与处理、建模仿真、程序设计、仿真代码、论文写作与指导&#xff0c;毕业论文、期刊论文经验交流。✅成品或者定制&#xff0c;扫描文章底部微信二维码。1)小波多尺度加权卷积神经网络的单机组诊断模型。风电机组监测系统采集的时序信号具有…

作者头像 李华