避坑指南: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同用即可。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

搭建动态网站之——基于Redhat8.6搭建Discuz论坛

一、动态网站与静态网站区别 动态网站并不是指具有动画功能的网站&#xff0c;而是指网站内容可根据不同情况动态变更的网站&#xff0c;一般情况下动态网站通过数据库进行架构。 动态网站除了要设计网页外&#xff0c;还要通过数据库和编程序来使网站具有更多自动的和高级的功…

【最新】2023年30米分辨率土地利用遥感监测数据

改革开放以来&#xff0c;中国经济的快速发展对土地利用模式产生了深刻的影响。同时&#xff0c;中国又具有复杂的自然环境背景和广阔的陆地面积&#xff0c;其土地利用变化不仅对国家发展&#xff0c;也对全球环境变化产生了深刻的影响。为了恢复和重建我国土地利用变化的现代…

网络安全事件频发现状

近日&#xff0c;腾讯视频、菜鸟、滴滴等App崩溃的消息登上热搜&#xff0c;引发不少网友热议。今年以来&#xff0c;已有多起App崩溃事件发生&#xff0c;甚至有企业因此业绩损失超亿元。互联网应用的系统安全和稳定性建设越来越被社会广泛关注。 12月3日晚&#xff0c;有网友…

Hadoop3.x完全分布式模式下slaveDataNode节点未启动调整

目录 前言 一、问题重现 1、查询Hadoop版本 2、集群启动Hadoop 二、问题分析 三、Hadoop3.x的集群配置 1、停止Hadoop服务 2、配置workers 3、从节点检测 4、WebUI监控 总结 前言 在大数据的世界里&#xff0c;Hadoop绝对是一个值得学习的框架。关于Hadoop的知识&…

司铭宇销售技巧培训师需要具备的功底

销售技巧培训师需要具备的功底 售技巧培训师是负责传授销售技巧和策略的专业人士&#xff0c;他们需要具备深厚的功底&#xff0c;以帮助销售人员提高销售业绩。以下是一些销售技巧培训师需要具备的功底 一、深厚的销售理论功底 销售技巧培训师要想在培训过程中游刃有余&…

SQL语句整理二--Mysql

文章目录 知识点梳理&#xff1a;1. mysql 中 in 和 exists 区别2. varchar 与 char 的区别 查看表结构&#xff1a;获取当前时间&#xff1a;查看建表语句&#xff1a;修改用户密码&#xff1a;查看所有用户&#xff1a;grant命令&#xff1a;判断当前数据库有多少连接数&…

智能优化算法应用:基于社会群体算法3D无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用&#xff1a;基于社会群体算法3D无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用&#xff1a;基于社会群体算法3D无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.社会群体算法4.实验参数设定5.算法结果6.…

HTML中边框样式、内外边距、盒子模型尺寸计算(附代码图文示例)【详解】

Hi i,m JinXiang ⭐ 前言 ⭐ 本篇文章主要介绍HTML中边框样式、内外边距、盒子模型尺寸计算以及部分理论知识 &#x1f349;欢迎点赞 &#x1f44d; 收藏 ⭐留言评论 &#x1f4dd;私信必回哟&#x1f601; &#x1f349;博主收将持续更新学习记录获&#xff0c;友友们有任何问…

78-C语言-完数的判断,以及输出其因子

简介&#xff1a;一个数如果恰好等于它的因子之和&#xff0c;这个数就称为完数&#xff0c;C语言编程找出1000之内的所有完数&#xff0c;并输出其因子。因子可以整除该数字的数&#xff0c; 如6的因子&#xff1a;1 2 3&#xff0c;6%10 6%20 6%30 解释全在注…

windows安装conda小环境 windows安装anaconda python jupyter anaconda

1 如果想体验在线版的jupyter&#xff0c;可以访问anaconda在Anaconda Cloud&#xff0c;需要注册github&#xff1a; 1 下载anaconda &#xff0c;并安装 1.1 下载 或者去清华镜像下载 Free Download | Anacondahttps://www.anaconda.com/downloadIndex of /anaconda/arch…

Template for directive ‘electronicSign‘ must have exactly one root element.

问题&#xff1a; 原因&#xff1a; angularjs 提示模版指令需要根元素 解决办法&#xff1a; 清理头尾

【ros2 control 机器人驱动开发】简单双关节机器人学习-example 1

【ros2 control 机器人驱动开发】简单双关节机器人学习-example 1 文章目录 前言一、RR机器人创建description pkg创建demos pkg 二、创建controller相关创建example pkg 三、测试运行总结 前言 本系列文件主要有以下目标和内容&#xff1a; 为系统、传感器和执行器创建 Har…

Amazon CodeWhisperer 在 vscode 的应用

文章作者:旧花阴 CodeWhisperer 是一款可以帮助程序员更快、更安全地编写代码的工具&#xff0c;可以在他们的开发环境中实时提供代码建议和推荐。亚马逊云科技发布的这款代码生成工具 CodeWhisperer 最大的优势就是对于个人用户免费。以在 vscode 为例&#xff0c;演示安装过程…

Python tkinter控件全集之组合选择框 ttk.ComboBox

Tkinter标准库 Tkinter是Python的标准GUI库&#xff0c;也是最常用的Python GUI库之一&#xff0c;提供了丰富的组件和功能&#xff0c;包括窗口、按钮、标签、文本框、列表框、滚动条、画布、菜单等&#xff0c;方便开发者进行图形界面的开发。Tkinter库基于Tk for Unix/Wind…

【Image】图像处理

计算机视觉 CV Perception 如自动驾驶领域。 只要是从所谓的图像当中去抽取信息的过程&#xff0c;我们都叫做Perception。 视觉检测可以涵盖二维检测&#xff0c;如车辆、人和信号灯的检测。另外&#xff0c;还可以控制三维信息&#xff0c;直接在三维空间中操作数据。 SL…

IDEA新建jdk8 spring boot项目

今天新建spring boot项目发现JDK版本最低可选17。 但是目前用的最多的还是JDK8啊。 解决办法 Server URL中设置&#xff1a; https://start.aliyun.com/设置完成后&#xff0c;又可以愉快的用jdk8创建项目了。 打包的jar无法运行 小伙伴可能会发现&#xff0c;默认的配置打…

9、ble_mesh基础

node节点&#xff0c;不属于网络的设备称为未配置设备。未配置的设备无法发送或接收网格消息&#xff1b;但是&#xff0c;它会向 Provisioners 宣传其存在。 Provisioner供应&#xff0c;验证&#xff0c;邀请&#xff0c;加入网络成为节点。 一个节点有多个控制或开关&#x…

四通道 DMOS 全桥驱动MS35631N/MS35631

MS35631N/MS35631 是一款四通道 DMOS 全桥驱动器&#xff0c;可以驱动两 个步进电机或者四个直流电机。每个全桥的驱动电流在 24V 电源下可以 达到 1.2A 。 MS35631N/MS35631 集成了固定关断时间的 PWM 电流校正 器&#xff0c;以及一个 2bit 的非线性 DAC &…

美颜SDK技术对比,深入了解视频美颜SDK的工作机制

如何在实时视频中呈现更加自然、美丽的画面&#xff0c;而这正是美颜SDK技术发挥作用的领域之一。本文将对几种主流视频美颜SDK进行深入比较&#xff0c;以揭示它们的工作机制及各自的优劣之处。 随着科技的不断进步&#xff0c;美颜技术已经从简单的图片处理发展到了视频领域…