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

news2025/1/10 21:03:47

​🌈个人主页:前端青山
🔥系列专栏: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.coloradmin.cn/o/1321241.html

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

相关文章

Pytorch nn.Linear()的基本用法与原理详解及全连接层简介

主要引用参考&#xff1a; https://blog.csdn.net/zhaohongfei_358/article/details/122797190 https://blog.csdn.net/weixin_43135178/article/details/118735850 nn.Linear的基本定义 nn.Linear定义一个神经网络的线性层&#xff0c;方法签名如下&#xff1a; torch.nn.Li…

AT32F403如何扩大SRAM

配置方法 使用雅特力的ICP 进行配置(可在官网下载) (1)当连接上芯片后,点击设备操作->选择字节 (2)选择224KB SRAM (3)然后点击应用到设备,(可以点击从设备加载,来看当前的配置) (4)打开keil5魔术棒图标 ,将Target中的IRAM1第二个选项从0x10000改为0x3800。…

虚拟电厂 能源物联新方向

今年有多热&#xff1f;据上海市气象局官微消息&#xff0c;5月29日13时09分&#xff0c;徐家汇站气温达36.1℃&#xff0c;打破了百年来的当地5月份气温*高纪录。不仅如此&#xff0c;北京、四川、江西、湖南、广东、广西等地也频频发布高温预警。 伴随着居民用电急剧攀升&am…

4.1 媒资管理模块 - Nacos与Gateway搭建

文章目录 媒资管理模块 - 媒资项目搭建一、需求分析1.1 介绍1.2 数据模型1.3 分析网关 二、 搭建Nacos2.1 服务发现中心2.2.1 Maven2.2.2 配置Nacos 2.2 配置中心2.2.1 介绍2.2.2 Maven 坐标2.2.3 配置 content-api 工程2.2.4 配置 content-service 工程2.2.5 配置 system-api …

基础算法(5):滑动窗口

1.何为滑动窗口&#xff1f; 滑动窗口其实也是一种算法&#xff0c;主要有两类&#xff1a;一类是固定窗口&#xff0c;一类是可变窗口。固定的窗口只需要一个变量记录&#xff0c;而可变窗口需要两个变量。 2.固定窗口 就像上面这个图一样。两个相邻的长度为4的红色窗口&…

HTML---CSS美化网页元素

文章目录 前言一、pandas是什么&#xff1f;二、使用步骤 1.引入库2.读入数据总结 一.div 标签&#xff1a; <div>是HTML中的一个常用标签&#xff0c;用于定义HTML文档中的一个区块&#xff08;或一个容器&#xff09;。它可以包含其他HTML元素&#xff0c;如文本、图像…

探秘 AJAX:让网页变得更智能的异步技术(上)

&#x1f90d; 前端开发工程师&#xff08;主业&#xff09;、技术博主&#xff08;副业&#xff09;、已过CET6 &#x1f368; 阿珊和她的猫_CSDN个人主页 &#x1f560; 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》 &#x1f35a; 蓝桥云课签约作者、已在蓝桥云…

如何编写好的测试用例?

对于软件测试工程师来说&#xff0c;设计测试用例和提交缺陷报告是最基本的职业技能。是非常重要的部分。一个好的测试用例能够指示测试人员如何对软件进行测试。在这篇文章中&#xff0c;我们将介绍测试用例设计常用的几种方法&#xff0c;以及如何编写高效的测试用例。 一、…

iPhone 17Pro/Max或升级4800万像素长焦镜头,配备自研Wi-Fi 7芯片。

iPhone 16未至&#xff0c;关于iPhone 17系列的相关消息就已经放出&#xff0c;到底是谁走漏了风声。 海通国际证券技术分析师Jeff Pu近日发布报告称&#xff0c;苹果将为2025年推出的iPhone 17ProMax配备4800万像素的长焦镜头。经调查&#xff0c;该分析师认为提升iPhone拍摄方…

如何在华为云上购买ECS及以镜像的方式部署华为云欧拉操作系统 (HCE OS)

写在前面 工作中遇到&#xff0c;简单整理博文内容为 华为云开发者认证 实验笔记https://edu.huaweicloud.com/certificationindex/developer/9bf91efb086a448ab4331a2f53a4d3a1理解不足小伙伴帮忙指正 对每个人而言&#xff0c;真正的职责只有一个&#xff1a;找到自我。然后在…

Nginx快速入门:Nginx应用场景、安装与部署(一)

1. Nginx简介 Nginx 是一个高性能的 HTTP 和反向代理服务器&#xff0c;也是一个非常流行的开源 Web 服务器软件。它是由俄罗斯程序员 Igor Sysoev 开发的&#xff0c;最初是为了解决在高并发场景下的C10k 问题&#xff08;即一个服务器进程只能处理 10,000 个并发连接&#x…

早期的OCR是怎么识别图片上的文字的?

现在的OCR技术融合了人工智能技术&#xff0c;通过深度学习&#xff0c;无论是识别的准确率还是效果都非常不错&#xff0c;那您知道在早期的OCR是通过什么技术来实现的吗&#xff1f;如果您不知道&#xff0c;那么&#xff0c;就让我来告诉您&#xff1a;它主要是基于字符的几…

DiffUtil + RecyclerView 在 Kotlin中的使用

很惭愧, 做了多年的Android开发还没有使用过DiffUtil这样解放双手的工具。 文章目录 1 DiffUtil 用来解决什么问题?2 DiffUtil 是什么?3 DiffUtil的使用4 参考文章 1 DiffUtil 用来解决什么问题? 先举几个实际开发中的例子帮助我们感受下: 加载内容流时,第一次加载了ABC,…

数据分析思维导图

参考&#xff1a; https://zhuanlan.zhihu.com/p/567761684?utm_id0 1、数据分析步骤地图 2、数据分析基础知识地图 3、数据分析技术知识地图 4、数据分析业务流程 5、数据分析师能力体系 6、数据分析思路体系 7、电商数据分析核心主题 8、数据科学技能书知识地图 9、数据挖掘…

文章解读与仿真程序复现思路——电力系统自动化EI\CSCD\北大核心《基于碳捕集-电转气的矿区综合能源系统协同优化调度》

这个标题涉及到碳捕集、电力转化为气体&#xff08;可能是指电力转化为氢气等&#xff09;、矿区综合能源系统以及协同优化调度等概念。让我们逐步解读&#xff1a; 碳捕集&#xff08;Carbon Capture&#xff09;&#xff1a; 这指的是通过不同技术手段捕获和隔离工业过程中产…

输电线路定位:精确导航,确保电力传输安全

在现代社会中&#xff0c;电力作为生活的基石&#xff0c;其安全稳定运行至关重要。而输电线路作为电力传输的重要通道&#xff0c;其故障定位和修复显得尤为重要。恒峰智慧科技将为您介绍一种采用分布式行波测量技术的输电线路定位方法&#xff0c;以提高故障定位精度&#xf…

新版Android Studio Logcat 筛选日志

下载了新版的Android Studio&#xff0c;android-studio-2022.3.1.21-mac_arm&#xff0c;记录一下新版本AS的logcat过滤日志条件 1. 按照包名过滤 1.1 过滤当前包名的日志 package:mine 1.2 过滤其他包名日志 package:com.example.firstemptyapplication 2. 按照日志等级过滤…

STM32与Freertos入门(三)任务的创建、删除

1、串口配置 首先将串口进行配置&#xff0c;后续经常会应用&#xff0c;具体步骤点击&#xff1a;串口配置。 2、任务 创建一个任务&#xff0c;就是开辟一个空间、每个任务中都会有while&#xff08;1&#xff09;死循环。 2.1相关函数 动态创建&#xff1a;xTaskCreate…

Github 2023-12-19开源项目日报 Top10

根据Github Trendings的统计&#xff0c;今日(2023-12-19统计)共有10个项目上榜。根据开发语言中项目的数量&#xff0c;汇总情况如下&#xff1a; 开发语言项目数量Python项目4Rust项目2非开发语言项目2C#项目1TypeScript项目1 Avalonia: 跨平台UI框架和Avalonia XPF 创建周…

20231218给Firefly的AIO-3399J【RK3399】开发板刷Android12挖掘机方案

20231218给Firefly的AIO-3399J【RK3399】开发板刷Android12挖掘机方案 2023/12/18 21:07 一、整体编译Rockchip的的Android12的挖掘机方案&#xff01; 由于RK3399的Android12系统默认是IND工业方案&#xff0c;需要修改一下【为挖掘机方案】。 Z:\3TB\81rk_android12_220722\…