先上代码。

login.wxml

<mp-toptips msg="{{error}}" type="error" show="{{error}}"></mp-toptips>

<view class="page-body">
<mp-form id="form" rules="{{rules}}" models="{{formData}}">
<mp-cells title="信息绑定" >
<mp-cell prop="name" title="姓名" ext-class="cell" >
<input bindinput="formInputChange" data-field="name" class="weui-input"/>
</mp-cell>
<mp-cell prop="phone" title="手机号" ext-class="cell" >
<input bindinput="formInputChange" data-field="phone" class="weui-input"/>
</mp-cell>
<mp-cell prop="company" title="单位名称" ext-class="cell" >
<picker bindchange="bindPickerChange1" value="{{company}}" range="{{companyArray}}" range-key="name">
<view class="picker">
{{formData['company'] ? companyArray[company].name : '请选择'}}
<input hidden data-field="company" value="{{formData['company'] ? companyArray[company].name : '请选择'}}" class="weui-input"/>
</view>
</picker>
</mp-cell> </mp-cells>
</mp-form> <view class="weui-btn-area">
<button class="weui-btn" type="primary" bindtap="submitForm">确定</button>
</view>
</view>

login.wxss

.cell .weui-cell__hd{
width:200rpx;
}

login.js

// pages/login/login.js

const app = getApp()

Page({

  /**
* 页面的初始数据
*/
data: {
// 单位
company:0,
companyArray:[
{
id:0,
name:'a'
},
{
id:1,
name: 'b'
}
],
rules: [{
name: 'name',
rules: { required: true, message: '姓名必填' },
}, {
name: 'phone',
rules: [{ required: true, message: '手机号必填' }, { mobile: true, message: '手机号格式不对' }],
}, {
name: 'company',
rules: { required: true, message: '单位名称必填' },
}],
formData:{}
},
formInputChange(e) {
const { field } = e.currentTarget.dataset
this.setData({
[`formData.${field}`]: e.detail.value
})
},
bindPickerChange1: function (e) {
this.setData({
company: e.detail.value,
[`formData.company`]: e.detail.value
})
}, submitForm() {
// console.log(this.selectComponent('#form'))
this.selectComponent('#form').validate((valid, errors) => {
// console.log('valid', valid, errors)
if (!valid) {
const firstError = Object.keys(errors)
if (firstError.length) {
this.setData({
error: errors[firstError[0]].message
}) }
} else {
// wx.showToast({
// title: '校验通过'
// })
// console.log(this.data.formData)
wx.showToast({
title: '绑定成功'
})
try {
// 同步接口立即写入
wx.setStorageSync('user', JSON.stringify(this.data.formData))
let token = wx.getStorageSync('user')
// console.log(token)
if (typeof app.globalData.haveToken === "boolean") {
app.globalData.haveToken = true
app.globalData.reloadFlag = true
}
// console.log(app.globalData.haveToken)
wx.switchTab({
url: '../index/index'
})
} catch (e) {
console.log('写入value2发生错误')
}
}
})
}
})
picker 是小程序自带的组件,类似于select,选择控件。
mp-* 是WeUI 的组件,使用之前需要在json文件中引入。
login.json
{
"component": true,
"usingComponents": {
"mp-toptips": "../../weui-miniprogram/toptips/toptips", // 悬浮提示
"mp-cell": "../../weui-miniprogram/cell/cell", // 布局用的
"mp-cells": "../../weui-miniprogram/cells/cells", // 布局用的,依赖 cell
"mp-form": "../../weui-miniprogram/form/form" // 表单,表单验证需要
}
}

下面是细节分析。

<mp-cell prop="company" title="单位名称" ext-class="cell" >
<picker bindchange="bindPickerChange1" value="{{company}}" range="{{companyArray}}" range-key="name">
<view class="picker">
{{formData['company'] ? companyArray[company].name : '请选择'}}
<input hidden data-field="company" value="{{formData['company'] ? companyArray[company].name : '请选择'}}" class="weui-input"/>
</view>
</picker>
</mp-cell>

formData是存表单数据的,默认空对象。

一开始的时候肯定是没有值的,所以选之前都会提示 请选择。

只要选过了,就有值了,表单验证就能通过,否则不能通过。

隐藏的输入框是配合表单的,可能不需要。

bindPickerChange1: function (e) {
this.setData({
company: e.detail.value,
[`formData.company`]: e.detail.value
})
},

对应的change 方法。

set 了两个值,一个是显示用的,一个是表单用的。

submitForm() {
// console.log(this.selectComponent('#form'))
this.selectComponent('#form').validate((valid, errors) => {
// console.log('valid', valid, errors)
if (!valid) {
const firstError = Object.keys(errors)
if (firstError.length) {
this.setData({
error: errors[firstError[0]].message
}) }
} else {
// wx.showToast({
// title: '校验通过'
// })
// console.log(this.data.formData)
wx.showToast({
title: '绑定成功'
})
try {
// 同步接口立即写入
wx.setStorageSync('user', JSON.stringify(this.data.formData))
let token = wx.getStorageSync('user')
// console.log(token)
if (typeof app.globalData.haveToken === "boolean") {
app.globalData.haveToken = true
app.globalData.reloadFlag = true
}
// console.log(app.globalData.haveToken)
wx.switchTab({
url: '../index/index'
})
} catch (e) {
console.log('写入value2发生错误')
}
}
})
}

表单验证方法。

校验规则是 this.data.rules.

this.data.rules 会和 this.data.formData 进行比对,如果rule里面相应值 formData没有就会校验失败,这是最简单的非空校验。

更复杂的校验在rules[index].rules数组中可以加对象,里面的每一个对象都会去验证。

以上。

微信小程序实战:表单与选择控件的结合的更多相关文章

  1. 微信小程序-form表单-获取用户输入文本框的值

    微信小程序-form表单-获取用户输入文本框的值 <input name='formnickname' class="textarea" placeholder=" ...

  2. 微信小程序_(表单组件)checkbox与label

    微信小程序组件checkbox官方文档 传送门 微信小程序组件label官方文档 传送门 Learn 一.checkbox组件 二.label组件与checkbox组件共用 一.checkbox组件 ...

  3. 微信小程序之表单验证

    表单验证 何为表单验证呢? 百度百科给出的回答是这样的: 表单验证是javascript中的高级选项之一.JavaScript 可用来在数据被送往服务器前对 HTML 表单中的这些输入数据进行验证 [ ...

  4. 微信小程序_(表单组件)button组件的使用

    微信小程序表单组件button官方文档 传送门 Learn 一.button组件的使用 一.button组件的使用 size:按钮的大小[默认值default] type:按钮的样式类型[默认值def ...

  5. 微信小程序之表单提交

    页面绑定很多事件! <view class="content"> <view class="user personal_func_list"& ...

  6. 微信小程序常用表单校验方法(手机号校验、身份证号(严格和非严格校验、验证码六位数字校验))

    util.js function isPhone(value) { if (!/^1(3|4|5|7|8)\d{9}$/.test(value)) { return false } else { re ...

  7. 微信小程序实战篇:商品属性联动选择(案例)

    本期的微信小程序实战篇来做一个电商网站经常用到的-商品属性联动选择的效果,素材参考了一点点奶茶. 效果演示:   商品属性联动.gif 代码示例 1.commodity.xml <!-- < ...

  8. Web前端_微信小程序实战开发

    微信小程序开发实战教程 一.微信小程序 它是一种混合开发的方式. 是安装在微信中的程序(一个程序最多2M空间). 1.1 注册 1  2 点击立即注册:进入下方页面 3  4 点击小程序进入表单填写页 ...

  9. 2017-01-11小程序form表单提交

    小程序form表单提交 1.小程序相对于之前的WEB+PHP建站来说,个人理解为只是将web放到了微信端,用小程序固定的格式前前端进行布局.事件触发和数据的输送和读取,服务器端可以用任何后端语言写,但 ...

随机推荐

  1. 谷歌Chrome成最受欢迎的浏览器 它为啥好用?

    毫无疑问,在搜索引擎领域,谷歌是绝对的主导者.但是,一般人却很容易低估我们受到的“控制”.比如,它的浏览器Chrome. 在不到九年的时间,谷歌Chrome浏览器已经成为全球使用最多的网页浏览器.目前 ...

  2. WeChair项目Alpha冲刺(9/10)

    团队项目进行情况 1.昨日进展    Alpha冲刺第九天 昨日进展: 前端:安排页面美化,设计实名认证 后端:更新dao层代码 数据库:修改数据表属性,与后端部署数据库交互 2.今日安排 前端:继续 ...

  3. 【论文笔记】Pyramidal Convolution: Rethinking Convolutional Neural Networks for Visual Recognition

    地址:https://arxiv.org/pdf/2006.11538.pdf github:https://github.com/iduta/pyconv 目前的卷积神经网络普遍使用3×3的卷积神经 ...

  4. 7-4 List Leaves (25分) JAVA

    Given a tree, you are supposed to list all the leaves in the order of top down, and left to right. I ...

  5. 恕我直言你可能真的不会java第7篇:像使用SQL一样排序集合

    在开始之前,我先卖个关子提一个问题:我们现在有一个Employee员工类. @Data @AllArgsConstructor public class Employee { private Inte ...

  6. 最新的一波Vue实战技巧,不用则已,一用惊人

    在Vue中,不同的选项有不同的合并策略,比如 data,props,methods是同名属性覆盖合并,其他直接合并,而生命周期钩子函数则是将同名的函数放到一个数组中,在调用的时候依次调用 在Vue中, ...

  7. 不同编程语言实现HelloWorld程序

    目录 C C# C++ HTML Java Python C #include <stdio.h> int main() { printf("Hello World!" ...

  8. scrapy分布式抓取基本设置

    scrapy本身并不是一个为分布式爬取而设计的框架,但第三方库scrapy-redis为其扩展了分布式抓取的功能,在分布式爬虫框架中,需要使用某种通信机制协调各个爬虫工作 (1)当前的爬取任务,下载+ ...

  9. Python3笔记007 - 2.4 数据类型

    第2章 python语言基础 python语法特点 保留字与标识符 变量 数据类型 运算符 输入和输出 2.4 数据类型 数据类型分为:空类型.布尔类型.数字类型.字节类型.字符串类型.元组类型.列表 ...

  10. sendRedirect()和forward()方法的区别

    sendRedirect()和forward()方法的区别 之前好像曾经整理过,但忘了放在哪里了,好像压根就没整理过,博客里也没有,故今天重新整理一下. 我们知道页面之间的跳转有两种方式:重定向与转发 ...