news 2026/5/1 6:29:20

对于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/1 6:26:56

macbook shell 客户端推荐 Electerm macbook 版本下载链接

Electerm macbook 版本下载链接 你可以通过以下几种方式下载 Electerm 的 MacBook 版本&#xff0c;推荐优先使用官方渠道以确保安全&#xff1a; 1. 官方及主流开源渠道 GitHub 官方发布页 这是最权威的下载来源。你可以访问 Electerm 的 GitHub Releases 页面&#xff0c;找…

作者头像 李华
网站建设 2026/4/30 23:43:05

Python基于Vue的高校摄影爱好者平台设计与实现 django flask pycharm

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

作者头像 李华
网站建设 2026/5/1 8:30:50

Python基于Vue的洗衣店管理系统- django flask pycharm

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

作者头像 李华
网站建设 2026/5/1 7:33:40

AI应用架构师必备:掌握这8个方法论,让AI成为数学研究的加速器

AI应用架构师必备&#xff1a;掌握这8个方法论&#xff0c;让AI成为数学研究的加速器关键词&#xff1a;AI应用架构师、方法论、AI、数学研究、加速器摘要&#xff1a;本文主要为AI应用架构师提供了8个重要的方法论&#xff0c;旨在让AI能够更好地成为数学研究的加速器。文章详…

作者头像 李华
网站建设 2026/5/1 8:42:44

【BISHI15】小红的夹吃棋

求解代码 public static void main(String[] args) throws IOException {BufferedReader br new BufferedReader(new InputStreamReader(System.in));StringTokenizer in new StringTokenizer(br.readLine());PrintWriter out new PrintWriter(new OutputStreamWriter(Syste…

作者头像 李华
网站建设 2026/5/1 7:40:11

Python 列表 vs 数组:深入解析与最佳选择指南

Python 列表 vs 数组&#xff1a;深入解析与最佳选择指南 ✨ 引言&#xff1a;数据结构的艺术 &#x1f3a8;第一章&#xff1a;Python列表 - 灵活多变的瑞士军刀 &#x1f527;1.1 列表的本质与特性1.2 列表的底层实现1.3 列表的实用案例 第二章&#xff1a;Python数组 - 专注…

作者头像 李华