【微信小程序-原生开发】实用教程19 - 表单范例 VS 表单校验(含必填校验函数封装,实时数字校验)

简介: 【微信小程序-原生开发】实用教程19 - 表单范例 VS 表单校验(含必填校验函数封装,实时数字校验)

表单开发中,最常见的即必填校验和数字校验

必填校验

当字段较多时,为了优化代码,将必填校验进行封装

必填校验函数封装 utils\form.js

export function formRequiredValid(formRule, formData) {
  let result = true
  let obj = formRule

  obj[Symbol.iterator] = function* () {
    let keys = Object.keys(obj);
    for (let k of keys) {
      yield [k, obj[k]];
    }
  };

  for (let [k, v] of obj) {
    if (!formData[k]) {
      wx.showToast({
        icon: 'none',
        title: `${v}不能为空`,
      })
      result = false
      break
    }
  }
  return result
}

使用范例

import {
  formRequiredValid
} from '../../../../utils/form.js'
 
  save: function () {
    let formRule = {
      title: "标题",
      date: "日期",
      time: "时间",
      placeInfo: "地点",
    }

    if (!formRequiredValid(formRule, this.data.formData)) {
      return
    }
    //  此处省略数据库的保存逻辑
 }

实时数字校验

数字类数据,需实时进行数据类型校验,如

<t-input clearable bindclear="inputChange" bindchange="inputChange" data-prop='maxNum' value="{{formData.maxNum}}" type="number" label="人数:" placeholder="请输入最大报名人数" suffix="人" align="right" t-class-tips="tips" tips="{{formError.maxNum ? '请输入数字' : ''}}" />

<t-input clearable bindclear="inputChange" bindchange="inputChange" data-prop='cost' value="{{formData.cost}}" type="number" label="费用:" placeholder="请输入人均费用" suffix="元/人" align="right" t-class-tips="tips" tips="{{formError.cost ? '请输入数字' : ''}}" />
    // 表单校验报错
    formError: {},
  inputChange: function (e) {
    let prop = e.currentTarget.dataset.prop
    let value = e.detail.value || '' //清空表单时,触发更新,避免清空时修改无效
    this.data.formData[prop] = value
    if (prop === 'date') {
      this.data.formData.week = getWeek(value)
    }
    // 对特殊字段进行正则校验
    if (prop === 'cost' || prop === 'maxNum') {
      const isNumber = value ? /^\d+(\.\d+)?$/.test(value) : true;
      this.data.formError[prop] = !isNumber
      this.setData({
        formError: this.data.formError
      });
      if (value && isNumber) {
        // 将数据格式化为数字
        this.data.formData[prop] = Number(value)
      }
    }
    this.setData({
      formData: this.data.formData
    })
  },
// 保存时, 校验是否通过数据校验
    if (Object.values(this.data.formError).includes(true)) {
      wx.showToast({
        icon: 'error',
        title: '未通过数据校验',
      })
      return
    }

其他实时校验

参考实时数字校验,修改对应的正则表达式即可,如邮箱校验,手机号校验等。

目录
相关文章
|
6月前
|
JSON 小程序 JavaScript
原生微信小程序笔记完整总结
原生微信小程序笔记完整总结
189 1
|
9月前
|
XML 小程序 前端开发
小程序制作教程
小程序制作教程
398 3
小程序制作教程
|
9月前
|
机器学习/深度学习 人工智能 JSON
微信小程序原生AI运动(动作)检测识别解决方案
近年来,疫情限制了人们的出行,却推动了“AI运动”概念的兴起。AI运动已在运动锻炼、体育教学、线上主题活动等多个场景中广泛应用,受到互联网用户的欢迎。通过AI技术,用户可以在家中进行有效锻炼,学校也能远程监督学生的体育活动,同时,云上健身活动形式多样,适合单位组织。该方案成本低、易于集成和扩展,已成功应用于微信小程序。
|
9月前
|
小程序 JavaScript API
微信小程序开发之:保存图片到手机,使用uni-app 开发小程序;还有微信原生保存图片到手机
这篇文章介绍了如何在uni-app和微信小程序中实现将图片保存到用户手机相册的功能。
2346 0
微信小程序开发之:保存图片到手机,使用uni-app 开发小程序;还有微信原生保存图片到手机
|
小程序 PHP
全新UI自助图文打印系统小程序源码 PHP后端 附教程
全新UI自助图文打印系统小程序源码 PHP后端 附教程
429 2
|
11月前
|
小程序 前端开发 JavaScript
微信小程序结合PWA技术,提供离线访问、后台运行、桌面图标及原生体验,增强应用性能与用户交互。
微信小程序结合PWA技术,提供离线访问、后台运行、桌面图标及原生体验,增强应用性能与用户交互。开发者运用Service Worker等实现资源缓存与实时推送,利用Web App Manifest添加快捷方式至桌面,通过CSS3和JavaScript打造流畅动画与手势操作,需注意兼容性与性能优化,为用户创造更佳体验。
397 0
|
11月前
|
存储 小程序 JavaScript
|
小程序 前端开发
【微信小程序-原生开发】实用教程22 - 绘制图表(引入 echarts,含图表的懒加载-获取到数据后再渲染图表,多图表加载等技巧)
【微信小程序-原生开发】实用教程22 - 绘制图表(引入 echarts,含图表的懒加载-获取到数据后再渲染图表,多图表加载等技巧)
700 0
|
小程序
【微信小程序-原生开发】实用教程21 - 分包
【微信小程序-原生开发】实用教程21 - 分包
594 0
|
3月前
|
小程序 Java 关系型数据库
weixin163基于微信小程序的校园二手交易平台系统设计与开发ssm(文档+源码)_kaic
本文介绍了一款基于微信小程序的校园二手物品交易平台的开发与实现。该平台采用Java语言开发服务端,使用MySQL数据库进行数据存储,前端以微信小程序为载体,支持管理员和学生两种角色操作。管理员可管理用户、商品分类及信息、交易记录等,而学生则能注册登录、发布购买商品、参与交流论坛等。系统设计注重交互性和安全性,通过SSM框架优化开发流程,确保高效稳定运行,满足用户便捷交易的需求,推动校园资源共享与循环利用。

热门文章

最新文章