uniapp---form(4)---from表单的应用
第一步:添加一个按钮,并且按钮的form-type属性添加为submit。想要在form表单的submit中得到值。这需要为其添加上name属性。第三歩:在生命周期methods里创建formSubmit方法接受值。第一步:添加一个按钮,并且按钮的form-type属性添加为reset。第三歩:点击reset按钮,即可清空form表单的内容。第二歩:在form表单的组件中添加事件 @submit。
·
文章目录
-
- form表单
- submit提交表单
- reset重置表单
文章内容
一、form表单
表单,将组件内的用户输入的<switch>
<input>
<checkbox>
<slider>
<radio>
<picker>
提交。
当点击 <form>
表单中 formType 为 submit 的 <button>
组件时,会将表单组件中的 value 值进
行提交,需要在表单组件中加上 name 来作为 key。
属性说明
属性名 | 类型 | 说明 | 平台差异说明 |
---|---|---|---|
report-submit | Boolean | 是否返回 formId 用于发送模板消息 | 微信小程序、支付宝小程序 |
report-submit-timeout | number | 等待一段时间(毫秒数)以确认 formId 是否生效。如果未指定这个参数,formId 有很小的概率是无效的(如遇到网络失败的情况)。指定这个参数将可以检测 formId 是否有效,以这个参数的时间作为这项检测的超时时间。如果失败,将返回 requestFormId:fail 开头的 formId | 微信小程序2.6.2 |
@submit | EventHandle | 携带 form 中的数据触发 submit 事件,event.detail = {value : {'name': 'value'} , formId: ''},report-submit 为 true 时才会返回 formId | |
@reset | EventHandle | 表单重置时会触发 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中配置字段的格式,前端表单校验和服务器入参校验将可以复用该规则,无需在前端后端重复开发表单校验。详见 - 有很多表单自助生成辅助工具
更多推荐
已为社区贡献13条内容
所有评论(0)