基于vant封装的动态表单(VFrom使用教程)

news2024/11/28 2:50:50

vant-ui是属于vue开发移动端中用的比较多的一个组件库了,网上基于它的一些组件的二次封装也数不胜数,但是却都是零零散散,不成体系。总不能用一个就去找类似的封装吧,这样拼凑起来的也不是我们想要的。尤其,涉及众多表单业务的时候。

1.场景需求 

假如你遇到这样一个场景,需要做一个表单收集。涉及到输入框,单选框,多选框,下拉框,时间选择等等七八个表单。基于vant-ui的情况下,去官网单个的去复制粘贴。就这样一个vue页面是不是起码就几百行了。这还不算假如是在一个tabs标签页下,每个标签页下都有七八个表单呢?

这个时候,阁下又该如何自处?组件化,那就多少个标签多少个组件。不利于维护。改起来也麻烦。写一个页面?哪起码上千行代码了。

先看下效果图,有个最直观的感受:

所以,当涉及多个表单时,我们就迫切的需要一个成体系化的二次封装表单。

2.vform使用说明

v-form: 🎉 基于Vant-UI进行二次封装动态生成表单,也可完全自定义控件,通过 JSON 的形式配置,内部集成繁琐的校验规则,可扩展的校验

文档有详细说明。照猫画虎对于一些动手能力强的人来说那就是手拿把掐。这里我也就不多加叙述了。

 3.从无到有

        文档上说的很清楚,也不得不承认它的封装的却是很好。不多相比于大多数业务场景而言,也用不到那么复制。就一个最常见的场景来说。生成表单,收集信息 这八个字就是我们的核心思想,迫切所需要的。

闲话少叙,跟随lz的脚步,我们一起实操下:

1.引入依赖,全局注册

 man.js

// 注册封装表单:https://gitee.com/cgb-lowcode/v-form
import VForm from '@xuanmo/v-form'
import '@xuanmo/v-form/packages/style/index.less'



Vue.use(VForm);
// 设置防抖时间,默认200ms
Vue.use(VForm, {
  debounceTime: 200
})

tips:项目技术栈是vue+vant。记得提前引入vant。

2.模拟动态表单数据

formModel.js

const formdata =  {
    family:[        
        { rules: { type: "VCell" } },
        {
            key:'text1',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra',
            }
        },
        {
            key:'text2',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        {
            key:'text3',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        {
            key:'text4',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        {
            key:'text5',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        {
            key:'text6',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        {
            key:'text7',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        { rules: { type: "VCell" } },
        {
            key:'text8',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        {
            key:'text9',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        {
            key:'text10',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        { rules: { type: "VCell" } },
        {
            key:'text11',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        {
            key:'text12',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        {
            key:'text13',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        {
            key:'text14',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        {
            key:'text15',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        }
    ],
    health:[        
        { rules: { type: "VCell" } },
        {
            key:'text1',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra',
            }
        },
        {
            key:'text2',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        {
            key:'text3',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        {
            key:'text4',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
    ],
    children:[        
        { rules: { type: "VCell" } },
        {
            key:'text1',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra',
            }
        },
        {
            key:'text2',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        {
            key:'text3',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        {
            key:'text4',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        { rules: { type: "VCell" } },
        {
            key:'text5',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra',
            }
        },
        {
            key:'text6',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
    ],
    retire:[     
        { rules: { type: "VCell" } },
        {
            key:'text1',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra',
            }
        },
        {
            key:'text2',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        {
            key:'text3',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        {
            key:'text4',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        {
            key:'text5',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        {
            key:'text6',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        { rules: { type: "VCell" } },
        {
            key:'text7',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        {
            key:'text8',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        {
            key:'text9',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
    ],
    riches:[        
        { rules: { type: "VCell" } },
        {
            key:'text1',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra',
            }
        },
        {
            key:'text2',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        {
            key:'text3',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        {
            key:'text4',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        },
        {
            key:'text5',    
            value: '',
            rules: {
                label: '文本',
                type: 'VInput',
                vRules: 'required',
                placeholder: '请输入',
                errorMsg: '请输入',
                extra: 'extra'
            }
        }
    ]


}
export default formdata;

3.vue页面使用

<template>
  <div class='dataedit'>
    <van-nav-bar
      title='数据收集'
      left-arrow
      @click-left='$router.back()'
    ></van-nav-bar>
    <div class="main">
        <van-tabs @disabled="onClickDisabled" @change="changeTab" v-model.number="active" sticky color="#FF6837" title-active-color="#FF6837" line-width="0.5rem">
          <van-tab disabled>
            <template #title><img src="@/assets/menu/11.png" alt="" style="width:0.8rem;height:0.8rem;margin-top:0.2rem"></template>
          </van-tab>
          <van-tab title="表单1">
              <v-form
                ref="vform"
                v-model="formValue.family"
                :model="model.family"
                :disabled="disabled"
                label-width="80%"
                :label-color="labelColor"
                @change="change"
              >
              </v-form>
          </van-tab>
          <van-tab title="表单2">
            <v-form
                ref="vform"
                v-model="formValue.health"
                :model="model.health"
                :disabled="disabled"
                label-width="80%"
                :label-color="labelColor"
                @change="change"
              >
              </v-form>
          </van-tab>
          <van-tab title="表单3">
            <v-form
                ref="vform"
                v-model="formValue.children"
                :model="model.children"
                :disabled="disabled"
                label-width="80%"
                :label-color="labelColor"
                @change="change"
              >
              </v-form>
          </van-tab>
          <van-tab title="表单4">
            <v-form
                ref="vform"
                v-model="formValue.retire"
                :model="model.retire"
                :disabled="disabled"
                label-width="80%"
                :label-color="labelColor"
                @change="change"
              >
              </v-form>
          </van-tab>
          <van-tab title="表单5">
            <v-form
                ref="vform"
                v-model="formValue.riches"
                :model="model.riches"
                :disabled="disabled"
                label-width="80%"
                :label-color="labelColor"
                @change="change"
              >
              </v-form>
          </van-tab>
        </van-tabs>
    </div>
    <div class="btn">
        <van-button round block type="info" color="#FF6837" to="/sys/data/addinfo">保存</van-button>
    </div>
  </div>
</template>

<script>
import formModel from "./formModel";
export default {
  name: 'dataedit',
  data () {
    return {
        active:1,
        model:formModel,
        disabled: false,        // 是否禁用表单
        labelColor: "inherit",  // label颜色
        formValue: {            // 表单值
          family:{},
          health:{},
          retire:{},
          children:{},
          riches:{}
        },
    }
  },
  mounted(){
    console.log("参数:",this.$route.query.id);
  },
  methods: {
    onClickDisabled(){
      console.log("点击头像");
    },
    change({ value, errorMsg, isValid }) {
      console.log("表单值:",value);
      this.formData = value;
      this.formError = errorMsg;
      this.isValid = isValid;
    },
    changeTab(val){
      console.log("当前标签===》",val);
    },
  }
}
</script>

<style lang='less' scoped>
    ::v-deep .v-form-container .v-form-row{
        min-height: 1.5rem;
        padding-top: 0.25rem;
    }
    .main{
      ::v-deep .van-tab__pane{
        height: 80vh;
        overflow-y: auto;
        padding-bottom: 1rem;
      }
    }
    .btn{
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        height: 1.6rem;
        display: flex;
        justify-content: center;
        align-items: center;
        background: #ffffff;
        padding: 0 5%;
    }
</style>

4.最终效果图

 数据是实时获取的。formModel.js定义的key值就是键。type为表单类型,如VInput,VRadio,VSelect等常用表单,label就是label文本,vRules是验证规则,placeholder是原生的placeholder,errorMsg就是验证失败提示。

其他的请自行查看文档。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/742064.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Python单元测试

单元测试 测试可以保证你的代码在一系列给定条件下正常工作测试允许人们确保对代码的改动不会破坏现有的功能测试迫使人们在不寻常条件的情况下思考代码&#xff0c;这可能会揭示出逻辑错误良好的测试要求模块化&#xff0c;解耦代码&#xff0c;这是一个良好的系统设计的标志…

Oracle select 和read的权限

只有select权限&#xff0c;也可以for update锁表。 我懵了一下&#xff0c;不确认啊&#xff0c;我先测试了下&#xff0c;如下所示&#xff1a; create user test11 identified by test11; create user test12 identified by test12; grant connect,resource to test11,tes…

【2022HVV系列】蓝队手册更新版(建议收藏)

本文首发于【2022HVV系列】蓝队手册更新版&#xff08;建议收藏&#xff09; 综合篇 青藤云安全出品&#xff1a; 倒计时&#xff01;你需要这份《2022攻防演练蓝队防守指南》 攻防演练合集 | 3个阶段&#xff0c;4大要点&#xff0c;蓝队防守全流程纲要解读网络安全实战攻防…

[QT编程系列-1]:C++图形用户界面编程,QT框架快速入门培训 - 0- 总述

目录 导言 主要内容 附录&#xff1a; 导言 1. 在这里强调为啥选择 PPT 方式&#xff0c;而不是直接讲解代码 2. 重原理和方法 3. 种 QT 的框架和 QT 的开发流程 4. 轻 UI 界面美观&#xff08; UI 设计单独课程&#xff09; 5. 请代码具体实现&#xff08;后期自学&#xf…

JavaScript 导出csv文件页面卡死时的处理方式

文章概叙 当我在使用xlsx包导出csv文件时候&#xff0c;数据过大导致页面卡死&#xff0c;因此才使用blob的方式来导出csv文件&#xff0c;如果没有出现这个问题&#xff0c;建议还是使用xlsx包 XLSX包 npm的地址&#xff0c;对于前后端开发的同学来说&#xff0c;文档难度不…

【SCI一区】互联燃料电池混合动力汽车通过信号交叉口的生态驾驶双层凸优化(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

LCD显示方向

LCD显示方向 一、ILI9341内存到显示地址的映射 本文只讨论“正常显示”&#xff0c;不讨论“垂直滚动显示”模式。 可以看到物理内存被两个指针访问&#xff0c;行指针和列指针&#xff0c;行指针范围从000h到013Fh&#xff0c;列指针范围为0000h到00EFh。也就是说&#xff0c…

naive-ui 的n-date-picker改变成中文

如下 那改完之后就要变成 如下 其实蛮简单的 修改app.vue import { zhCN,dateZhCN } from "naive-ui";<n-config-provider :locale"zhCN" :date-locale"dateZhCN"><RouterView /></n-config-provider> 你要是卡到前端难题&a…

Graphics Mill 11.1.18 -24-06-2023 Crack

Graphics Mill 是适用于 .NET 和 ASP.NET 开发人员的最强大的成像工具集。它允许用户轻松向 .NET 应用程序添加复杂的光栅和矢量图像处理功能。 加载和保存 JPEG、PNG 和另外 8 种图像格式 调整大小、裁剪、自动修复、色度键和 30 多种其他图像操作 可处理任何尺寸&#xff08…

P3 第一章 电路模型与电路定律

1、在电路当中&#xff0c;理想电源的阻值与理想电源的u-i特性无关。 理想电压源的内阻是零&#xff0c;理想电流源的内阻是无穷。而在电路中的等效阻值有电路的连接情况决定。 发电机、蓄电池工作特性接近于电压源&#xff0c;电路模型表达为电压源电阻串联。 光电池特性比较…

《MySQL》内置函数

文章目录 日期函数字符串函数数学函数其他函数 日期函数 函数名称功能current_date()当前日期&#xff08;yyyy-mm-dd&#xff09;current_time()当前时间&#xff08;hh-mm-ss&#xff09;current_timestamp()当前时间戳&#xff08;yyyy-mm-dd hh-mm-ss&#xff09;now()当前…

缓存 - Spring Boot 整合 Caffeine 不完全指北

文章目录 Pre名词解释注解属性指导步骤步骤 1&#xff1a;添加依赖步骤 2&#xff1a;配置缓存步骤 3&#xff1a;使用缓存 CodepomConfigService缓存名枚举 & 常量测试入口测试 Pre 缓存 - Caffeine 不完全指北 名词解释 Cacheable&#xff1a;表示该方法支持缓存。当调…

Few-Shot Learning in Wireless Networks: A Meta-Learning Model-Enabled Scheme

1 INTRODUCTION 由于6G的复杂管理机制&#xff0c;可以在基站收集历史数据——为克服训练数据集容量的限制提供了极大的便利 问题与挑战&#xff1a; 尽管元学习可以提高网络边缘智能(network edge intelligence)的性能&#xff0c;但其在无线网络(wireless networks)中的应用…

HCIP实验---OSPF实验2

1.如图连接&#xff0c;合理规划IP地址&#xff0c;所有路由器各自创建一个loopback接口 2.R1再创建三个接口IP地址为201.1.1.1/24、201.1.2.1/24、201.1.3.1/24 R5再创建三个接口IP地址为202.1.1.1/24、202.1.2.1/24、202.1.3.1/24 R7再创建三个接口IP地址为203.1.1.1/2…

高效办公学习的秘密!打工人高效工作必备的AI神器

​人工智能 (AI) 近年来取得了显著进步&#xff0c;并已成为科技行业的流行语。我们随时能看到大量有关人工智能工具的资讯&#xff0c;它有可能自动执行任务&#xff0c;节省时间并提高效率&#xff0c;使其成为企业的宝贵资产和平台。 随着人工智能的进步&#xff0c;旨在让…

如何在Ubuntu18.04中下载MySQL5.7

检查环境 首先检查自己电脑有没有安装过mysql,输入如下&#xff1a; rpm -qa | grep mysql如果有则清理干净在安装&#xff0c;输入 whereis mysql找到文件夹目录&#xff0c;再把它删除 rpm -e --nodeps mysql-xxx检查系统是否自带mariadb&#xff0c;输入如下检查 rpm -…

基于Tars高并发IM系统的设计与实现-实战篇1

基于Tars高并发IM系统的设计与实现-实战篇1 通过前文基础篇&#xff0c;进阶篇的介绍&#xff0c;相信大家已经对IM的基础能力实现&#xff0c;难点及其如何解决有了一个全面的了解与认识。 相信大家都迫不及待想看看一个高性能的IM系统到底怎么设计与实现&#xff0c;从本篇开…

grpc学习笔记

目录 gRPC原理网络传输效率问题基本概念概览ClientServer 异步相关概念异步 Client异步 Server gRPC原理 RPC 即远程过程调用协议&#xff08;Remote Procedure Call Protocol&#xff09;&#xff0c;可以让我们像调用本地对象一样发起 远程调用。 网络传输效率问题 HTTP…

Mysql---explain详解

explain命令是用来分析查询语句的执行计划的工具。它可以显示查询语句的执行计划&#xff0c;包括查询的顺序、使用的索引、扫描的行数等信息&#xff0c;帮助开发人员优化查询语句的性能。通过分析执行计划&#xff0c;可以找到查询语句的瓶颈&#xff0c;进而优化查询语句的性…

机器学习笔记 - 探索PaddlePaddle框架的对象检测、分割和关键点检测

一、PaddlePaddle简述 PaddlePaddle(PArallel Distributed Deep LEarning)是百度于2016年发布的开源深度学习框架。它为各种机器学习任务提供了统一的平台。 但是最近的基准测试显示 PaddlePaddle 是潜在的领跑者,其基准速度超过了其更知名的竞争对手。 PaddlePaddle 与 PyT…