避坑指南:uni-forms表单在uni-app中的实践经验

​🌈个人主页:前端青山
🔥系列专栏:uni-app篇
🔖人终将被年少不可得之物困其一生

依旧青山,本期给大家带来JavaScript篇专栏内容:uni-app中forms表单的避坑指南篇

该篇章已被前端圈子收录,点此处进入即可查看更多优质内容

目录

1.uni-forms表单验证时“多级结构对象数据”如何做数据校验的解决方案​

2.uni-forms表单对象内嵌套循环数据(可增删)​

3.接收上一页返回参数​

4.根据单选判断显示内容(真机测试混乱或不生效)​

1.uni-forms表单验证时“多级结构对象数据”如何做数据校验的解决方案​

如果我们返回的字段为对象嵌套形式时

js

infoObj: {Info: {name:'',id:'',phone:'',sex:''},InfoSub: {name:'',id:'',phone:'',sex:''},},

uni-forms-item 需要设置 name 属性为当前字段名,字段为 String|Array 类型。

js

<uni-forms ref="form" :modelValue="infoObj" :rules="rules"label-position="top" label-width="400">//:modelValue绑定最外层的对象     <uni-forms-item  :name="['InfoSub','phone']" label="电话号码" ><uni-easyinput v-model="infoObj.InfoSub.phone" placeholder="请输入电话号码" /></uni-forms-item>//name属性以数组形式['对象嵌套对象名','要校验的name名称']
</uni-forms>

最后给当前uni-forms-item 单独设置设置 :rules="校验规则方法名" 属性,自己定义校验规则就可。

2.uni-forms表单对象内嵌套循环数据(可增删)​

只有一条数据时

前端圈子

多条数据时

前端圈子

数据格式为对象内嵌套循环数组

js

data() {return {infoObj: {name:'',phone:'',id:'',sex:'',//对象内嵌套循环数组addInfoList: [{name: '', sex: '', id: '', phone: '', }],},}},

完整代码如下

js

<template><view class="container"><uni-forms ref="form" :modelValue="infoObj"   label-width="400"><view  v-for="(item,index) in infoObj.addInfoList" :key="index" calss="addBox"><view class="dataFormTitle">员工信息{{index+1}}</view><uni-forms-item name="name" label="姓名" ><uni-easyinput v-model="infoObj.name" placeholder="请输入姓名" /></uni-forms-item><uni-forms-item name="phone" label="电话" ><uni-easyinput v-model="infoObj.phone" placeholder="请输入电话号码" /></uni-forms-item><uni-forms-item name="phone" label="年龄" ><uni-easyinput v-model="infoObj.phone" placeholder="请输入年龄" /></uni-forms-item><view class="delete" @click="toDelete(index)">删除</view></view></uni-forms><view class="addList"><text @click="toAdd">添加员工信息</text></view><view class="submit"><text @click="submit(index)">提交</text></view></view>
</template>
<script>export default {data() {return {infoObj: {name:'',phone:'',id:'',sex:'',//对象内嵌套循环数组addInfoList: [{name: '', sex: '', id: '', phone: '', }],},}},onLoad() {},methods: {//添加新数组方法toAdd(){let obj = {name: '',sex: '', id: '', phone: '', };this.infoObj.addInfoList.push(obj)},//删除数组方法toDelete(index){this.infoObj.addInfoList.splice(index,1)},//提交方法submit(index){//提交时将循环数组进行遍历let addInfo = this.infoObj.addInfoList.map(item => ({name: item.name,phone: item.phone,id: item.id,sex: item.sex}));uni.request({url:'http://www.jichuangsoft.com:8088/study/',data:{name:this.infoObj.name,phone:this.infoObj.phone,id:this.infoObj.id,sex:this.infoObj.sex,addInfoList:addInfo,}}).then(res=>{console.log('提交成功')}).catch(err=>{console.log('错误信息')})}}}
</script>

3.接收上一页返回参数​

在做uni-app 项目时,我们经常需要做上一页面传值的情况,其实原理也非常简单,先看效果

前端圈子

  • 定义一个变量来获取页面栈信息getCurrentPages()
  • 继续声明变量通过页面栈信息来返回上一页面pages[pages.length -2]
  • 通过返回上一页面变量名上一面变量名.$vm.函数名(参数1,参数2,参数3)
  • 最后在上一页面的methods方法内直接使用该函数来获取所收到的参数进行赋值

整体代码如下:

/pages/table表单页面

js

<template><view class="table_index"><uni-section title="接收的数据" type="line"></uni-section><uni-forms :modelValue="formData">	<uni-forms-item label="姓名" name="name"><uni-easyinput type="text" v-model="formData.name" placeholder="请输入姓名" /></uni-forms-item><uni-forms-item required name="hobby" label="职务"><uni-easyinput type="text" v-model="formData.duty" placeholder="请输入职务" /></uni-forms-item><uni-forms-item required name="corp" label="单位"><uni-easyinput type="corp" v-model="formData.corp" placeholder="请输入单位名称" /></uni-forms-item><button class="uni-button" size="mini" type="primary"  @click="toTable">选择职员信息</button></uni-forms></view>
</template>
<script>export default {data() {return {formData: {id: '',name: '',corp: '',duty: '',},}},methods:{toTable(){//跳转到选择职员数据页面uni.navigateTo({url:'/pages/demo/table/index'})},//在此页面使用上一页面所定义函数名来接收参数setTable(id,name,duty,corp){this.formData.name = name//获取到的名称this.formData.corp = corp//获取到的单位名称this.formData.duty = duty//获取到的职务},}}
</script>
<style scoped>.table_index {background-color: #fff;height: 100%;padding: 20px 30px;}.uni-button{font-size: 18px;width: 100%;height: 80rpx;display: flex;align-items: center;justify-content: center;}
</style>

pages/table/index职员信息页面

js

<template><view class="table_index"><uni-table border stripe emptyText="暂无更多数据"><!-- 表头行 --><uni-tr><uni-th width="10" align="center">序号</uni-th><uni-th width="50" align="center">名称</uni-th><uni-th width="50" align="center">职务</uni-th><uni-th width="70" align="center">单位</uni-th><uni-th width="50" align="center">操作</uni-th></uni-tr><!-- 表格数据行 --><uni-tr v-for="(item,index) in tableList " :key="item.id"><uni-td align="center">{{index}}</uni-td><uni-td align="center">{{item.name}}</uni-td><uni-td align="center">{{item.duty}}</uni-td><uni-td align="center">{{item.corp}}</uni-td><uni-td><view class="uni-group"><button class="uni-button" size="mini" type="primary"@click="toEnter(item.id,item.name,item.duty,item.corp)">选择</button></view></uni-td></uni-tr></uni-table></view>
</template><script>export default {data() {return {tableList: [{id: 1,name: '张三',corp: '文化传媒',duty: '主管'},{id: 2,name: '李思思',corp: '电子科技',duty: '职员'},{id: 3,name: '王麻子',corp: '教育机构',duty: '司机'},{id: 4,name: '李四',corp: '餐饮酒店',duty: '职员'},{id: 5,name: '美羊羊',corp: '汽车销售',duty: '秘书'},], //初始数据}},onLoad() {},methods: {toEnter(id, name, duty, corp) {let pages = getCurrentPages() //获取当前页面栈信息let prevPage = pages[pages.length - 2]; //指向上一个页面prevPage.$vm.setTable(id, name, duty, corp) //定义函数名进行传参uni.navigateBack({delta: 1, //返回上一个页面})}}}
</script>
<style scoped>.table_index {background-color: #fff;height: 100%;padding: 20px 15px;}
</style>

注意:必须获取当前getCurrentPages()页面栈信息与pages[pages.length -2]长度减去对应数字来返回你想要返回参数的页面

4.根据单选判断显示内容(真机测试混乱或不生效)​

前端圈子

这种切换在开发过程或者H5页面时看似正常,但是打包到app或者真机模拟测试时,会出现混乱或者不生效的问题,此时change事件的赋值你是否以正常e.detail.value形式赋值给单选框,

是否已经忘记v-if与v-show的区别

  1. 当需要在两种状态之间切换时,可以使用 v-show
  2. 当需要根据复杂的条件决定是否渲染某个元素时,可以使用 v-if

将之前v-if判断改为v-show后,再次进行测试

别急,如果还未生效,那就是动态渲染时出现名称混乱或位置有差异的情况,那我们紧接着进行手动赋值

定义一个变量,如只有两个选项切换,默认置为false即可,如有多个,可以数字形式替代。

js

data() {return {checkStatus:false,//当只有两个选项切换时,默认为false即可checkStatus1:0,//当出现多个选项切换时,以数字或字符串形式赋值},

之后,在单选框的change事件进行单独赋值,如文字未生效,则在该状态下单独定义变量文字,v-show同用即可。

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

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

相关文章

计算机网络考研辨析(后续整理入笔记)

文章目录 体系结构物理层速率辨析交换方式辨析编码调制辨析 链路层链路层功能介质访问控制&#xff08;MAC&#xff09;信道划分控制之——CDMA随机访问控制轮询访问控制 扩展以太网交换机 网络层网络层功能IPv4协议IP地址IP数据报分析ICMP 网络拓扑与转发分析&#xff08;重点…

阶段十-springsecurity总结

jwt认证流程 SpringSecurity 认证过程 第一步&#xff1a; 创建一个类实现UserDetailsService接口&#xff0c;重写其中的方法 通过重写 public UserDetails loadUserByUsername(String username) 方法 从数据库校验用户输入的用户名 配置SecurityConfig Bean注入 Passwor…

类中成员函数及普通函数地址获取方式

文章目录 代码准备测试演示注意事项成员函数类型申明测试演示总的打印输出 代码准备 头文件:Calc.h #pragma onceclass Calc { public:int add(int,int);//函数声明static int sub(int,int);//函数声明 public:int b;//定义了一个成员变量static int a;//声明了一个静态成员变…

SG3524控制的恒流源电路图

SG3524简介 SG3524是开关电源脉宽调制型控制器。应用于开关稳压器&#xff0c;变压器耦合的直流变换器&#xff0c;电压倍增器&#xff0c;极性转换器等。采用固定频率&#xff0c;脉冲宽度调制&#xff08;脉宽调制&#xff09;技术。输出允许单端或推挽输出。芯片电路包括电…

lvs负载均衡

lvs负载均衡群集 群集 特点&#xff1a;由多台主机构成&#xff0c;都干同一件事&#xff0c;对外显示一个整体 企业集群分类 负载均衡群集高可用群集高性能运算群集 负载均衡群集&#xff08;LB&#xff09; 负载均衡的作用 提高应用系统的响应能力可以处理更多的访问请…

Bifrost 中间件 X-Requested-With 系统身份认证绕过漏洞复现

0x01 产品简介 Bifrost是一款面向生产环境的 MySQL,MariaDB,kafka 同步到Redis,MongoDB,ClickHouse等服务的异构中间件 0x02 漏洞概述 Bifrost 中间件 X-Requested-With 存在身份认证绕过漏洞,未经身份认证的攻击者可未授权创建管理员权限账号,可通过删除请求头实现身…

动态加载库

no_mangle 不要改标识符 首先是认识这个标注&#xff1a;mangle&#xff0c;英文的含义“撕裂、碾压”。我第一次把这个单次误以为是manage&#xff0c;说实话两个单词还挺像的。 RUS中函数或静态变量使用#[no_mangle]这个标注属性后&#xff0c;编译器就不会修改它们的名字了…

Home Assistant 如何开启SSH服务

环境&#xff1a; Home Assistant 11.2 SSH & Web Terminal 17.0 问题描述&#xff1a; Home Assistant 如何开启SSH服务 解决方案&#xff1a; 通过添加一个名为Terminal & SSH的插件来在 Home Assistant 中启用 SSH 服务 下面是启用 SSH 服务的大致步骤&#x…

C++第一讲之初入C++

注&#xff1a;本文是对于学完C语言再学C同学的讲解&#xff0c;主要补充C与C语言不同之处&#xff0c;如果你没学过C语言&#xff0c;不建议观看本文。 一.C简介 我们都知道C语言是过程性语言&#xff08;强调的是实现过程&#xff09;&#xff0c;即对计算机语言要处理的两…

计算机组成原理(存储器的校验)

存储器的校验 说到存储器的校验就是海明码&#xff08;汉明码&#xff09;&#xff0c;这种题型有两种&#xff1a; 1.编码问题&#xff1a;根据要传送的二进制代码来确定其对应的海明码&#xff08;汉明码&#xff09; 2.检错问题&#xff1a;已知收到的汉明码&#xff0c;…

【Linux】Linux运维基础

Linux简介&#xff1a; Linux是一个开源的操作系统内核&#xff0c;最初由Linus Torvalds创建。它通常与GNU工具一起使用&#xff0c;以创建一个完整的操作系统。Linux操作系统有许多基于内核的发行版&#xff0c;如Ubuntu、CentOS、Debian等&#xff0c;每个发行版都有其独特的…

深度学习中常见的激活函数

前文介绍 我们在前面了解到了线性回归模型&#xff0c;其实我们可以把线性回归看成一个单个的神经元&#xff0c;它实际上就完成了两个步骤 1.对输入的特征的加权求和 2.将结果通过传递函数&#xff08;或者激活函数&#xff09;输出 这里我们提到了传递函数&#xff08;或者…

HarmonyOS4.0从零开始的开发教程18后台代理提醒

HarmonyOS&#xff08;十六&#xff09;后台代理提醒 简介 随着生活节奏的加快&#xff0c;我们有时会忘记一些重要的事情或日子&#xff0c;所以提醒功能必不可少。应用可能需要在指定的时刻&#xff0c;向用户发送一些业务提醒通知。例如购物类应用&#xff0c;希望在指定时…

PDF天花板工具 你值得拥有

今天带来的推送是PDF文档阅读器的鼻祖——Adobe 的 Arcobat。 Adobe Acrobat 是由Adobe公司开发的一款PDF&#xff08;Portable Document Format&#xff0c;便携式文档格式&#xff09;编辑软件。借助它&#xff0c;您可以以PDF格式制作和保存你的文档 &#xff0c;以便于浏览…

MATLAB 点云中心化 (40)

MATLAB 点云中心化 一、算法介绍二、算法实现一、算法介绍 使用点云集合中的坐标计算质心,这里将其作为中心,将每个点坐标减去该中心坐标,即可得到中心化的点云,这在很多处理中是必须进行的一个步骤:相当于点云移动到以质心为原点的坐标系 (主要是计算质心和点云偏移两个…

【Maven-Helper】利用 Maven-Helper 解决依赖冲突问题

【Maven-Helper】利用 Maven-Helper 解决依赖冲突问题 1&#xff09;安装 Maven-Helper 插件2&#xff09;Maven Helper 插件使用方法3&#xff09;Idea-Maven 可视化依赖树 1&#xff09;安装 Maven-Helper 插件 这里我们已经安装过了&#xff0c;如果没有安装过&#xff0c;点…

透视表美化——将透视表个别错误值去掉/取消自动更新表宽

1.问题&#xff1a;做透视表时&#xff0c;有时候有个别值求出来是错误值&#xff0c;但是不雅观需要删掉&#xff1b; 2.解决方案 点击数据透视表分析-选项框&#xff0c;将“对于错误值&#xff0c;显示&#xff1a;”选中&#xff0c;可以不填值或者填需要替代的值&#xf…

Ubuntu20.04 下编译安装 ffmpeg 和 ffplay

Ubuntu20.04 下编译安装 ffmpeg 和 ffplay 一、下载源码包二、安装依赖库三、编译四、添加环境变量五、验证是否成功六、问题 一、下载源码包 1.1 官方下载链接&#xff1a;http://ffmpeg.org/download.html 最新版本为6.1&#xff0c;点击 Download Source Code下载即可 &…

四、Spring IoC实践和应用(基于XML配置方式组件管理)

本章概要 基于XML配置方式组件管理 实验一&#xff1a; 组件&#xff08;Bean&#xff09;信息声明配置&#xff08;IoC&#xff09;实验二&#xff1a; 组件&#xff08;Bean&#xff09;依赖注入配置&#xff08;DI&#xff09;实验三&#xff1a; IoC 容器创建和使用实验四…

自助借还办证一体机软件需求说明书

1. 简介 1.1 项目概括 本项目主要实现读者自助办证、借书、还书、查询、续借的功能&#xff0c;减轻管理员的工作量&#xff0c;提升读者的借阅体验&#xff0c;提高了图书的借阅量与流通率&#xff0c;是图书馆智能化、无人化建设的重要步骤。 1.2 项目背景 ​ 目前各大图…