uniapp的动态表单实现

目录

1.说明

2.示例

3.总结


1.说明

①在 formData 中定义个数组变量用来接受同一个字段的多个结果。

复制代码
dynamicFormData: {
	email: '',
	// domains 字段下会有多个结果
	domains: []
}

②使用 uni-forms-itemrules 属性定义单个表单域的校验规则。

复制代码
<uni-forms-item :label="item.label+' '+index" required
	:rules="[{'required': true,errorMessage: '域名项必填'}]" :key="item.id">
	...
</uni-forms-item>

name 需要动态指定,动态表单推荐使用 Array 类型,内容从左到右为绑定值的调用链。['domains',index,'value'] 等同于 dynamicFormData.domains[index].value

复制代码
<uni-forms-item 
	required
	:label="item.label+' '+index" 
	:name="['domains',index,'value']"
	:rules="[{'required': true,errorMessage: '域名项必填'}]" 
	:key="item.id"
	>
	...
</uni-forms-item>

④需要绑定值的组件的 v-model 也需要动态指定 dynamicFormData.domains[index].value

复制代码
<uni-forms-item 
	required
	:label="item.label+' '+index" 
	:name="['domains',index,'value']"
	:rules="[{'required': true,errorMessage: '域名项必填'}]" 
	:key="item.id"
	>
	<uni-easyinput v-model="dynamicFormData.domains[index].value" placeholder="请输入域名" />
</uni-forms-item>

2.示例

html层:

复制代码
			<div v-for="(item,index) in formData.parts">
				<uni-forms-item class="is-direction-top" :label="index == 0?'参与人':''" :required="index == 0"
					:rules="[{'required': true,errorMessage: '请输入参与人'}]" :key="item.id" :name="['parts',index,'value']">
					<template v-slot:label v-if="index > 0">
						<div></div>
					</template>
					<view class="dmc">
						<uni-easyinput v-model="formData.parts[index].value" placeholder="请输入参与人" />
						<uni-icons class="dmc-btn" v-if="!index" @click="addParts" size="30" type="plus"
							color="#666"></uni-icons>
						<uni-icons class="dmc-btn" v-if="index" @click="delParts(index)" size="30" type="minus"
							color="#e43d33"></uni-icons>
					</view>
				</uni-forms-item>
			</div>
			<div v-for="(item,index) in formData.workTime">
				<uni-forms-item class="is-direction-top" :label="index == 0?'工作时间':''" :required="index == 0"
					:rules="[{'required': true,errorMessage: '请输入工作时间'}]" :key="item.id"
					:name="['workTime',index,'value']">
					<template v-slot:label v-if="index > 0">
						<div></div>
					</template>
					<view class="dmc">
						<uni-datetime-picker type="datetimerange" v-model="formData.workTime[index].value" hide-second :clear-icon="false"
							placeholder="请输入工作时间"  />
						<uni-icons class="dmc-btn" v-if="!index" @click="addWorkTime" size="30" type="plus"
							color="#666"></uni-icons>
						<uni-icons class="dmc-btn" v-if="index" @click="delWorkTime(index)" size="30" type="minus"
							color="#e43d33"></uni-icons>
					</view>
				</uni-forms-item>
			</div>

js层:

复制代码
	const resetForm = () => {
		return {
			bsNo: stationInfo.bsNo,
			bsName: stationInfo.deptNm,
			fieldNo: '',
			fieldNm: '',
			cropKey: '',
			cropValue: '',
			mediNm: '',
			mediAcreage: '',
			saKey: '',
			saValue: '',
			mediPerMu: '',
			dosageMediKey: '',
			dosageMediValue: '',
			mediTotalMu: '',
			mediContent: '',
			mediModeKey: '',
			mediModeValue: '',
			participants: '',
			parts: [{ value: getUser().userName, id: Date.now() }],
			workTime: [{ value: [moment.now(), moment.now()], id: Date.now() }],
			timeList: [] as any,
			tempCount: NaN,
			mediType: 6
		}
	};
	// 初始表单数据设置
	let formData = ref(resetForm());

3.总结

当某个字段为动态时,要用数组来存放多个值;要注意校验规则的写法。

我使用的是包含id及value的对象结构用来存在动态表单的数据。

相关推荐
郑州光合科技余经理1 天前
技术架构:上门服务APP海外版源码部署
java·大数据·开发语言·前端·架构·uni-app·php
HashTang1 天前
【AI 编程实战】第 6 篇:告别复制粘贴 - 设计一个优雅的 HTTP 模块
前端·uni-app·ai编程
iOS阿玮1 天前
苹果开发者账号申请的痛点,包含新限制说明!
uni-app·app·apple
2501_915921431 天前
iOS App 中 SSL Pinning 场景下代理抓包失效的原因
android·网络协议·ios·小程序·uni-app·iphone·ssl
雪芽蓝域zzs1 天前
uniapp 获取app版本信息(兼容鸿蒙)
uni-app
一颗小青松1 天前
uniapp app端使用uniCloud云函数和云对象
uni-app
2501_916008891 天前
在 Windows 上使用开心上架(Appuploader)在 Windows 环境下创建与管理 iOS 证书
android·ios·小程序·https·uni-app·iphone·webview
qq_316837752 天前
uniapp打包的微信小程序和h5两个项目 微信小程序webview打开h5 ,h5发送消息到小程序
微信小程序·小程序·uni-app
fxshy2 天前
uniapp结合uniCloud开发的微信小程序,在开发本地接口可以正常,但是线上异常,配置服务器域名解决
微信小程序·小程序·uni-app
技术宅小温2 天前
< uni-app开发核心难点解析:框架适配与打包发布全流程踩坑指南 >
前端·前端框架·uni-app·web app