欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

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

前言

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

基本用法

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

示例代碼

以下是一個包含多個校驗規(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: '用戶名長度應(yīng)在3到15個字符之間', trigger: 'blur' }
        ],
        email: [
          { required: true, message: '郵箱不能為空', trigger: 'blur' },
          { type: 'email', message: '請輸入有效的郵箱地址', trigger: 'blur' }
        ],
        password: [
          { required: true, message: '密碼不能為空', trigger: 'blur' },
          { min: 6, max: 20, message: '密碼長度應(yīng)在6到20個字符之間', trigger: 'blur' }
        ]
      }
    };
  },
  methods: {
    submitForm() {
      this.$refs.form.validate((valid) => {
        if (valid) {
          console.log('表單提交成功');
        } else {
          console.log('表單校驗失敗');
          return false;
        }
      });
    }
  }
};
</script>

校驗規(guī)則詳解

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

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

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

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

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

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

附:更多自定義的校驗

例如:再次確認(rèn)密碼的,在data中定義一個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中定義一個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('請再次輸入密碼'))
      }
    }
 ...
}

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

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

總結(jié)

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

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

相關(guān)文章

  • axios發(fā)送post請求springMVC接收不到參數(shù)的解決方法

    axios發(fā)送post請求springMVC接收不到參數(shù)的解決方法

    下面小編就為大家分享一篇axios發(fā)送post請求springMVC接收不到參數(shù)的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • Vue使用CDN引用項目組件,減少項目體積的步驟

    Vue使用CDN引用項目組件,減少項目體積的步驟

    這篇文章主要介紹了Vue使用CDN引用項目組件,減少項目體積的步驟,幫助大家提高項目加載速度,感興趣的朋友可以了解下
    2020-10-10
  • vue axios基于常見業(yè)務(wù)場景的二次封裝的實現(xiàn)

    vue axios基于常見業(yè)務(wù)場景的二次封裝的實現(xiàn)

    這篇文章主要介紹了vue axios基于常見業(yè)務(wù)場景的二次封裝的實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • vue中展示、讀取.md?文件的方法(批量引入、自定義代碼塊高亮樣式)

    vue中展示、讀取.md?文件的方法(批量引入、自定義代碼塊高亮樣式)

    這篇文章主要介紹了vue中展示、讀取.md?文件的方法(批量引入、自定義代碼塊高亮樣式),本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-05-05
  • vue中defineProperty和Proxy的區(qū)別詳解

    vue中defineProperty和Proxy的區(qū)別詳解

    這篇文章主要介紹了vue中defineProperty和Proxy的區(qū)別詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • vue中動態(tài)路由加載組件,找不到module問題及解決

    vue中動態(tài)路由加載組件,找不到module問題及解決

    這篇文章主要介紹了vue中動態(tài)路由加載組件,找不到module問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • 在Vue中實現(xiàn)拖拽功能的實例

    在Vue中實現(xiàn)拖拽功能的實例

    Vue實現(xiàn)拖拽功能的基本原理是監(jiān)聽鼠標(biāo)事件,實時更新拖拽元素的位置,最后在合適的時機(jī)停止拖拽并更新元素位置,在Vue中,我們可以通過綁定相關(guān)事件來實現(xiàn)這一功能
    2025-02-02
  • Vue2.0 組件傳值通訊的示例代碼

    Vue2.0 組件傳值通訊的示例代碼

    本篇文章主要介紹了Vue2.0 組件傳值通訊的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • vue-cli腳手架-bulid下的配置文件

    vue-cli腳手架-bulid下的配置文件

    這篇文章主要介紹了vue-cli腳手架-bulid下的配置文件,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-03-03
  • 通過vue方式實現(xiàn)二維碼掃碼功能

    通過vue方式實現(xiàn)二維碼掃碼功能

    這篇文章給大家介紹了通過vue的方式,實現(xiàn)掃碼功能,實現(xiàn)步驟分為兩步,本文通過實例代碼給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧
    2021-11-11

最新評論