文章目录

    • form表单
    • submit提交表单
    • reset重置表单

文章内容

一、form表单

表单,将组件内的用户输入的<switch> <input> <checkbox> <slider> <radio> <picker> 提交。

当点击 <form> 表单中 formType 为 submit 的 <button> 组件时,会将表单组件中的 value 值进

行提交,需要在表单组件中加上 name 来作为 key。

属性说明
属性名类型说明平台差异说明
report-submitBoolean是否返回 formId 用于发送模板消息微信小程序、支付宝小程序
report-submit-timeoutnumber等待一段时间(毫秒数)以确认 formId 是否生效。如果未指定这个参数,formId 有很小的概率是无效的(如遇到网络失败的情况)。指定这个参数将可以检测 formId 是否有效,以这个参数的时间作为这项检测的超时时间。如果失败,将返回 requestFormId:fail 开头的 formId微信小程序2.6.2
@submitEventHandle携带 form 中的数据触发 submit 事件,event.detail = {value : {'name': 'value'} , formId: ''},report-submit 为 true 时才会返回 formId
@resetEventHandle表单重置时会触发 reset 事件

 使用说明:

<template>
	<view>
		<view>
			<form @submit="formSubmit" @reset="formReset">
				<view class="uni-form-item uni-column">
					<view class="title">switch</view>
					<view>
						<switch name="switch" />
					</view>
				</view>
				<view class="uni-form-item uni-column">
					<view class="title">radio</view>
					<radio-group name="radio">
						<label>
							<radio value="radio1" /><text>选项一</text>
						</label>
						<label>
							<radio value="radio2" /><text>选项二</text>
						</label>
					</radio-group>
				</view>
				<view class="uni-form-item uni-column">
					<view class="title">checkbox</view>
					<checkbox-group name="checkbox">
						<label>
							<checkbox value="checkbox1" /><text>选项一</text>
						</label>
						<label>
							<checkbox value="checkbox2" /><text>选项二</text>
						</label>
					</checkbox-group>
				</view>
				<view class="uni-form-item uni-column">
					<view class="title">slider</view>
					<slider value="50" name="slider" show-value></slider>
				</view>
				<view class="uni-form-item uni-column">
					<view class="title">input</view>
					<input class="uni-input" name="input" placeholder="这是一个输入框" />
				</view>
				<view class="uni-btn-v">
					<button form-type="submit">Submit</button>
					<button type="default" form-type="reset">Reset</button>
				</view>
			</form>
		</view>
	</view>
</template>
<script>
	export default {
		data() {
			return {
			}
		},
		methods: {
			formSubmit: function(e) {
				console.log('form发生了submit事件,携带数据为:' + JSON.stringify(e.detail.value))
				var formdata = e.detail.value
				uni.showModal({
					content: '表单数据内容:' + JSON.stringify(formdata),
					showCancel: false
				});
			},
			formReset: function(e) {
				console.log('清空数据')
			}
		}
	}
</script>
<style>
	.uni-form-item .title {
		padding: 20rpx 0;
	}
</style>

 

 

二、submit提交表单

使用submit提交表单获取信息

第一步:添加一个按钮,并且按钮的form-type属性添加为submit

	<button form-type="submit">Submit</button>

第二歩:在form表单的组件中添加事件 @submit

<form @submit="formSubmit">

 第三歩:在生命周期methods里创建formSubmit方法接受值

formSubmit: function(e) {
				console.log(e.detail.value)
			}

注意:

想要在form表单的submit中得到值。这需要为其添加上name属性 

三、reset重置表单

使用reset重置表单

第一步:添加一个按钮,并且按钮的form-type属性添加为reset

<button type="default" form-type="reset">Reset</button>

第二歩:在form表单的组件中添加事件 @reset

<form @submit="formSubmit" @reset="formReset">

 第三歩:点击reset按钮,即可清空form表单的内容

 官方扩展

增强的uni-forms组件
  • 为方便做表单验证,uni ui提供了<uni-forms>组件,参考:uni-forms 表单 - DCloud 插件市场
  • 如果使用uniCloud,其数据库提供了DB Schema,在schema中配置字段的格式,前端表单校验和服务器入参校验将可以复用该规则,无需在前端后端重复开发表单校验。详见
  • 有很多表单自助生成辅助工具
    • 如果使用uniCloud的DB Schema可以自动生成全套表单,包括界面、校验逻辑、提交入库,详见.
    • 不使用uniCloud的话,插件市场有可视化拖拽表单插件:详见。这类插件只生成界面,没有逻辑。
Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐