亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue3表單組件el-form校驗(yàn)規(guī)則rules屬性示例詳解

 更新時(shí)間:2024年08月17日 09:21:19   作者:和燁  
在el-form中正確使用rules校驗(yàn)是非常重要的,rules使用不當(dāng)容易出現(xiàn)規(guī)則不生效、規(guī)則一直被觸發(fā)等各種現(xiàn)象,這篇文章主要給大家介紹了關(guān)于Vue3表單組件el-form校驗(yàn)規(guī)則rules屬性的相關(guān)資料,需要的朋友可以參考下

前言

在使用 Element UI (現(xiàn)在稱為 Element Plus) 的表單組件 el-form 時(shí),rules 屬性用于定義表單項(xiàng)的校驗(yàn)規(guī)則。這些規(guī)則可以幫助你確保用戶輸入的數(shù)據(jù)符合預(yù)期的格式和要求。

基本用法

rules 是一個(gè)對(duì)象,其中每個(gè)鍵對(duì)應(yīng)一個(gè)表單項(xiàng)的字段名,值是一個(gè)或多個(gè)校驗(yàn)規(guī)則。常見的校驗(yàn)規(guī)則包括必填、數(shù)據(jù)類型、最小長(zhǎng)度、最大長(zhǎng)度、自定義校驗(yàn)等。

示例代碼

以下是一個(gè)包含多個(gè)校驗(yàn)規(guī)則的示例:

<template>
  <el-form :model="formData" :rules="rules" ref="form">
    <el-form-item label="用戶名" prop="username">
      <el-input v-model="formData.username"></el-input>
    </el-form-item>
    <el-form-item label="郵箱" prop="email">
      <el-input v-model="formData.email"></el-input>
    </el-form-item>
    <el-form-item label="密碼" prop="password">
      <el-input type="password" v-model="formData.password"></el-input>
    </el-form-item>
    <el-button type="primary" @click="submitForm">提交</el-button>
  </el-form>
</template>

<script>
export default {
  data() {
    return {
      formData: {
        username: '',
        email: '',
        password: ''
      },
      rules: {
        username: [
          { required: true, message: '用戶名不能為空', trigger: 'blur' },
          { min: 3, max: 15, message: '用戶名長(zhǎng)度應(yīng)在3到15個(gè)字符之間', trigger: 'blur' }
        ],
        email: [
          { required: true, message: '郵箱不能為空', trigger: 'blur' },
          { type: 'email', message: '請(qǐng)輸入有效的郵箱地址', trigger: 'blur' }
        ],
        password: [
          { required: true, message: '密碼不能為空', trigger: 'blur' },
          { min: 6, max: 20, message: '密碼長(zhǎng)度應(yīng)在6到20個(gè)字符之間', trigger: 'blur' }
        ]
      }
    };
  },
  methods: {
    submitForm() {
      this.$refs.form.validate((valid) => {
        if (valid) {
          console.log('表單提交成功');
        } else {
          console.log('表單校驗(yàn)失敗');
          return false;
        }
      });
    }
  }
};
</script>

校驗(yàn)規(guī)則詳解

  • required: 表示該字段是否為必填項(xiàng)。
  • message: 校驗(yàn)失敗時(shí)顯示的錯(cuò)誤提示信息。
  • trigger: 觸發(fā)校驗(yàn)的時(shí)機(jī),常見的值有 'blur' 和 'change'。
  • type: 指定校驗(yàn)的數(shù)據(jù)類型,如 'string'、'number''email'、'url' 等。
  • min 和 max: 指定字符串長(zhǎng)度或數(shù)值的范圍,只在 type 為 'string' 或 'number' 時(shí)有效。
  • 自定義校驗(yàn)函數(shù): 可以通過 validator 屬性定義一個(gè)自定義的校驗(yàn)函數(shù)。

自定義校驗(yàn)函數(shù)示例

有時(shí)候內(nèi)置的校驗(yàn)規(guī)則無(wú)法滿足需求,這時(shí)可以使用自定義校驗(yàn)函數(shù):

rules: {
  password: [
    { required: true, message: '密碼不能為空', trigger: 'blur' },
    { min: 6, max: 20, message: '密碼長(zhǎng)度應(yīng)在6到20個(gè)字符之間', trigger: 'blur' },
    { validator: validatePasswordStrength, trigger: 'blur' }
  ]
}

function validatePasswordStrength(rule, value, callback) {
  if (!/\d/.test(value)) {
    callback(new Error('密碼必須包含至少一個(gè)數(shù)字'));
  } else if (!/[a-zA-Z]/.test(value)) {
    callback(new Error('密碼必須包含至少一個(gè)字母'));
  } else {
    callback();
  }
}

在這個(gè)示例中,validatePasswordStrength 函數(shù)被用作自定義校驗(yàn)函數(shù),確保密碼至少包含一個(gè)數(shù)字和一個(gè)字母。

附:更多自定義的校驗(yàn)

例如:再次確認(rèn)密碼的,在data中定義一個(gè)const 常量,在rules中引入

1. 在form表單中加入rules,并加上prop=‘’

<el-form ref="form" :model="form" :rules="rules" size="small" label-width="88px">
	<el-form-item label="確認(rèn)密碼" prop="confirmPass">
        <el-input v-model="form.confirmPass" type="password" auto-complete="on" style="width: 370px;" />
    </el-form-item>
...
</el-form>

2.在data中定義一個(gè)const 常量

data(){
	// 定義規(guī)則 (rule, value, callback) 
	const confirmPass = (rule, value, callback) => {
      if (value) {
        if (this.form.newPass !== value) {
          callback(new Error('兩次輸入的密碼不一致'))
        } else {
          callback()
        }
      } else {
        callback(new Error('請(qǐng)?jiān)俅屋斎朊艽a'))
      }
    }
 ...
}

3. 在rules中引入自定義的規(guī)則confirmPass

rules:{
	oldPass: [
       { required: true, message: '請(qǐng)輸入舊密碼', trigger: 'blur' }
     ],
     newPass: [
       { required: true, message: '請(qǐng)輸入新密碼', trigger: 'blur' },
       { min: 6, max: 20, message: '長(zhǎng)度在 6 到 20 個(gè)字符', trigger: 'blur' }
     ],
	confirmPass: [
       { required: true, validator: confirmPass, trigger: 'blur' }
   ]
...
}

總結(jié)

通過合理配置 el-form 中的 rules 屬性,可以實(shí)現(xiàn)復(fù)雜的表單校驗(yàn)邏輯,提升表單的易用性和數(shù)據(jù)的可靠性。根據(jù)具體需求選擇合適的校驗(yàn)規(guī)則和觸發(fā)時(shí)機(jī),是實(shí)現(xiàn)高質(zhì)量表單的關(guān)鍵。

到此這篇關(guān)于Vue3表單組件el-form校驗(yàn)規(guī)則rules屬性的文章就介紹到這了,更多相關(guān)Vue3 el-form校驗(yàn)規(guī)則rules屬性內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論