vue批量验证form表单数据

2 篇文章 0 订阅

批量验证用户表单栏是否为空,正则判断是否正确

参考文章:

vue批量验证提交表单的数据是否合规 - 曾经的水哥 - 博客园

 然后进行了部分代码更改如下:

<template>
    <div class="from_box">
        <form action="">
          <ul>
              <li>
                  姓名:
                  <input type="text" v-model="formMess.name">
              </li>
              <li>
                  年龄:
                  <input type="number" v-model="formMess.age">
              </li>
              <li>
                  体重:
                  <input type="number" v-model="formMess.weight">
              </li>
              <li>
                  手机:
                  <input type="phone" v-model="formMess.phone">
              </li>
              <li>
                  邮箱:
                  <input type="email" v-model="formMess.email">
              </li>
              <li>
                  地址:
                  <input type="text" v-model="formMess.address">
              </li>
          </ul>
          <span @click="inspect" class="but">点击测试数据是否正确</span>
        </form>
    </div>
</template>

<script>
import axios from 'axios';

export default {
  name: "from",
  data() {
    return {
      formMess: {
        name: '',
        age: '',
        weight: '',
        phone: '',
        email: '',
        address: ''
      },
      checkdata:[
            {
                inspect: "", // 待检测的字段
                msg: '姓名', // 空值返回的提示
            },
            {
                inspect: "",
                msg: '年龄'
            },
            {
                inspect: "",
                msg: '体重'
            },
            {
                inspect: "",
                msg: '手机号',
                reg: '^[1][3,4,5,7,8][0-9]{9}$'
            },
            {
                inspect: "",
                msg: '邮箱',
                reg: '^[a-z0-9]+([._\\-]*[a-z0-9])*@([a-z0-9]+[-a-z0-9]*[a-z0-9]+.){1,63}[a-z0-9]+$'
            },
            {
                inspect: "",
                msg: '地址'
            }
        ]
    };
  },
  methods: {
    // 判定是否合规
    have_empty(arr) {
        for (let key in arr) {
          if(arr[key].inspect && arr[key].reg){ // 有值并且有规则执行验证
            let reg = new RegExp(arr[key].reg)
            var red_end = reg.test(arr[key].inspect)
            if( !red_end ){
                console.log('请输入正确的' + arr[key].msg)
                return false
            }
          }else if(!arr[key].inspect){
                console.log('请输入' + arr[key].msg)
                return false
          }
        }
        return true
    },
    // 判定规则前传入参数
    inspect() {
        this.assignData();
        var end = this.have_empty(this.checkdata);
        if (!end) return // 判定验证结果
        console.log('执行提交的ajax函数')

    },
    assignData() {//赋值
      var arrForm = [];
      for(let key in this.formMess){
        arrForm.push(key);
      }
      for(let i = 0;i<this.checkdata.length;i++){
        var key = arrForm[i];
        this.checkdata[i].inspect = this.formMess[arrForm[i]];
      }
    }
  },
  mounted() {

  }
};
</script>

<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped lang="less">
.from_box{
  font-size: .14rem;
  form{
    padding:5%;
    width:90%;
    margin: auto;
    border:.01rem solid gray;
    display: flex;
    flex-wrap: wrap;
    input{
      width:80%;
      height:.5rem;
      margin-bottom: .2rem;
      border:.01rem solid black;
      height:.5rem;
    }
  }
  .but{
    font-size: .14rem;
    margin-left:5%;
    background: gray;
    padding:6px;
    color: #fff;
  }
}
</style>

vue form表单数据提交

vue form表单数据提交_caimingxian401的博客-CSDN博客_vue表单提交

喜欢可点赞/ 收藏/ 评论,有人回应才有动力继续更新哒!\‘▽′/

  • 5
    点赞
  • 36
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

caicaicai404

对作者使用钞能力,欢迎点这里

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值