时间:2021-05-18
微信小程序中form 表单提交和取值实例详解
我们知道,如果我们直接给 input 添加 bindinput,比如:<input bindinput="onUsernameInput" />,那么可以在 onUsernameInput 中直接使用 e.detail.value,即:
onUsernameInput : function(e) { e.detail.value;}但是,如果有多个输入控件,我们不可能为每个控件添加 bindinput、bindchange 这类方法来获取值。我们得这样做:
第一步、添加 from 控件,并为其指定 bindsubmit 属性值。
第二步、添加输入控件到 form 中,并为其指定 name 属性值。
第三步、添加 button 控件,并为其指定 form-type="submit"。
第四步、在 js 中取值时,用 e.detail.value.xxx 或 e.detail.value["xxx"],其中 xxx 为 name 属性值。
.wxml 代码
<form bindsubmit="reg"> <view>用户:<input type="text" name="username" /></view> <view>密码:<input password name="password" /></view> <view>兴趣:<checkbox-group name="cb"> <label><checkbox value="A" />乒乓球</label> <label><checkbox value="B" checked="false" />羽毛球</label> <label><checkbox value="C" checked="{{checked}}" />排球</label> </checkbox-group></view> <view>级别:<radio-group name="r"> <label><radio value="a" />初级</label> <label><radio value="b" />中级</label> <label><radio value="c" />高级</label> </radio-group></view> <view><button type="primary" form-type="submit">注册</button></view></form>.js 代码
reg: function(e) { console.log(e.detail.value); wx.showToast({ title: e.detail.value["cb"].join(","), icon: "success", duration: 2000 });}重要说明
<input type="text" 中的 type 和 HTML 中的不同,
微信小程序的 input 有个属性叫 type,这个 type 有几个可选值:
text:不必解释
number:数字键盘(无小数点)
idcard:数字键盘(无小数点、有个 X 键)
digit:数字键盘(有小数点)
注意:number 是无小数点的,digit 是有小数点的。我严重怀疑这是个 BUG。
<input password /> 表示密码框(个人认为太怪异,不如直接叫 password 标签的好)。
“羽毛球”那一项,我们是故意写作 checked="false" 的,我们试图使之初始不选中,但是不如我们愿,它却选中了,这和 HTML 一样,并不认 checked 属性值,只认有没有这个标记。不过如果我们使用 {{}} 则不一样,比如“排球”一项,选中与否就受 data.checked 的影响。
input 的取值如前面所述,用 e.detail.value.xxx 或 e.detail.value["xxx"],其中 xxx 为 name 属性。
checkbox 的取值也是类似 input,不过 xxx 为 checkbox-group 的 name,取出来的值是数组,由选中项的 value 组成,比如选中了“乒乓球”、“排球”,结果就是:["1", "3"]。特别说明,这个顺序与我们选择的先后有关,比如我们先选择“排球”,再选择“乒乓球”,结果就是["3", "1"]。
radio 的取值和 input 一样,返回的是选中的那一项的 value,没有选中项就是 ""。
如果不知道值类型,也可用 console.log(e.detail.value); 将所有值输出来,然后在调试 Console 中观察值,再来取。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了微信小程序提交form操作。分享给大家供大家参考,具体如下:在微信小程序中也存在form组件,bindsubmit这个属性可以用于携带form中的
微信小程序表单Form实例表单Form的应用很广泛,我们可以利用form设计登录注册,也可以设计一种答题问卷的形式,今天主要讲一下form的使用form表单,将
微信小程序promsie.all和promise顺序执行一、前言最近在做小程序的开发,碰到的一个需求就是表单提交,提交的表单中包含有图片,微信这边的做法是先上传
本文实例讲述了微信小程序表单验证功能。分享给大家供大家参考,具体如下:Wxml女士先生提交正在提交...app.jsimportwxValidatefrom'u
form表单中的button按钮提交:放在form表单中,会有一个提交事件,会提交form数据,