vue的element组件校验-手机号/电话号\邮箱\身份证号

原文噜啦噜

<template>
  <div>
    <el-form
      :model="ruleForm"
      :rules="rules"
      ref="ruleForm"
      label-width="100px"
      class="demo-ruleForm"
    >
      <el-form-item label="手机号"  prop="phone">
        <el-input v-model="ruleForm.phone"></el-input>
      </el-form-item>
        <el-form-item label="身份证号"  prop="idNumber">
        <el-input v-model="ruleForm.idNumber"></el-input>
      </el-form-item>
        <el-form-item label="邮箱"  prop="email">
        <el-input v-model="ruleForm.email"></el-input>
      </el-form-item>
      <el-form-item>
        <el-button type="primary" @click="submitForm('ruleForm')">立即创建</el-button>
        <el-button @click="resetForm('ruleForm')">重置</el-button>
      </el-form-item>
    </el-form>
  </div>
</template>
<script>
export default {
  data() {
    return {
      ruleForm: {
        phone: "",
        email: "",
        idNumber: "",
      },
      rules: {
        phone: [
          { required: true, message: "请输入手机号", trigger: "blur" },
          // 这个只能验证手机号
          // { pattern:/^0{0,1}(13[0-9]|15[7-9]|153|156|18[7-9])[0-9]{8}$/, message: "请输入合法手机号", trigger: "blur" }
          { pattern:/^((0\d{2,3}-\d{7,8})|(1[3584]\d{9}))$/, message: "请输入合法手机号/电话号", trigger: "blur" }
        ],
        idNumber: [
         { required: true, message: "请输入身份证号", trigger: "blur" },
          { pattern:/(^[1-9]\d{5}(18|19|([23]\d))\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\d{3}[0-9Xx]$)|(^[1-9]\d{5}\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\d{2}$)/, message: "请输入合法身份证号", trigger: "blur"}
        ],
          email: [
         { required: true, message: "请输入邮箱", trigger: "blur" },
          { pattern:/^([0-9A-Za-z\-_\.]+)@([0-9a-z]+\.[a-z]{2,3}(\.[a-z]{2})?)$/g, message: "请输入正确的邮箱", trigger: "blur"}
        ],
      }
    };
  },
  methods: {
    submitForm(formphone) {
      this.$refs[formphone].validate(valid => {
        if (valid) {
          alert("submit!");
        } else {
          console.log("error submit!!");
          return false;
        }
      });
    },
    resetForm(formphone) {
      this.$refs[formphone].resetFields();
    }
  }
};
</script>
<style lang="less">
  .el-input__inner {
    width: 200px;
  }
</style>
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue3结合Element Plus使用JS实现电话号码和邮箱校验可以通过以下步骤: 1. 安装Element Plus 在终端中运行以下命令安装Element Plus: ``` npm install element-plus --save ``` 2. 引入Element Plus 在你的Vue组件中,引入Element Plus的必要组件: ```javascript <template> <div> <el-input v-model="phone" placeholder="请输入手机号"></el-input> <el-button type="primary" @click="checkPhone">校验手机号码</el-button> <el-input v-model="email" placeholder="请输入邮箱"></el-input> <el-button type="primary" @click="checkEmail">校验邮箱</el-button> </div> </template> <script> import { reactive } from 'vue'; import { ElInput, ElButton } from 'element-plus'; import 'element-plus/lib/theme-chalk/index.css'; export default { components: { ElInput, ElButton, }, setup() { const state = reactive({ phone: '', email: '', }); const checkPhone = () => { const phoneReg = /^[1][3-9][0-9]{9}$/; if (!phoneReg.test(state.phone)) { alert('请输入正确的手机号码'); } else { alert('手机号码正确'); } }; const checkEmail = () => { const emailReg = /^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$/; if (!emailReg.test(state.email)) { alert('请输入正确的邮箱地址'); } else { alert('邮箱地址正确'); } }; return { ...state, checkPhone, checkEmail, }; }, }; </script> ``` 3. 在模板中,使用Element Plus提供的ElInput和ElButton组件来分别接收用户输入的电话号码和邮箱地址,并且使用v-model指令来绑定到state.phone和state.email属性上。 4. 在checkPhone和checkEmail函数中,定义好需要校验的正则表达式,并且使用test方法来检查用户输入是否符合格式要求。如果不符合,弹出错误提示,否则提示正确。 通过以上步骤,就可以在Vue3结合Element Plus使用JS实现电话号码和邮箱校验了。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值