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

關(guān)于ElementPlus中的表單驗(yàn)證規(guī)則詳解

 更新時(shí)間:2023年06月07日 17:18:29   作者:秋天code  
這篇文章主要介紹了關(guān)于ElementPlus中的表單驗(yàn)證,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

關(guān)于ElementPlus中表單的校驗(yàn)規(guī)則,官網(wǎng)文檔已經(jīng)給出了,但是沒有說明性文字,所以我想來記錄一下,給出一些文字說明

ElementPlus中的簡(jiǎn)單校驗(yàn)

ElementPlus的表單的一般結(jié)構(gòu)是:

<el-form>
	<el-form-item>
		<el-input/>
	</el-form-item>
</el-form>

ElementPlus中使用表單校驗(yàn)規(guī)則:

  • <script>中給出校驗(yàn)規(guī)則對(duì)象,主要屬性名要與form對(duì)象的屬性名一致
  • 一個(gè)字段的校驗(yàn)規(guī)則可以有多個(gè),值是一個(gè)數(shù)組,數(shù)組中的一個(gè)對(duì)象就是一條校驗(yàn)規(guī)則
// 收集表單數(shù)據(jù)
const form = reactive({
  account: '',
  password: '',
  agree: false
})
// 定義校驗(yàn)規(guī)則
// 可以為一個(gè)字段指定多條校驗(yàn)規(guī)則
// 規(guī)則名稱與form表單字段一致
const rules = reactive({
  account: [
    // required是否必填,message不符合此規(guī)則時(shí)的提示信息,
    // trigger觸發(fā)此條規(guī)則校驗(yàn)的時(shí)機(jī),有兩個(gè)值, blur 或 change,默認(rèn)就是blur和change都會(huì)進(jìn)行校驗(yàn)
    // min此字段的最小長(zhǎng)度,max此字段的最大長(zhǎng)度
    // pattern 正則表達(dá)式
    { required: true, message: '賬戶不能為空', trigger: 'blur' },
    { min: 6, max: 14, message: '用戶名長(zhǎng)度為6 - 14位' }
  ]
})

在模版中:

  • <el-form>rules屬性綁定規(guī)則校驗(yàn)對(duì)象
  • <el-form-item>prop屬性綁定規(guī)則對(duì)象的某個(gè)字段
<!--
  :model 綁定表單對(duì)象
  :rules 綁定表單的校驗(yàn)規(guī)則
-->
<el-form
  status-icon
  :model="form"
  :rules="rules"
>
  <!--
	label標(biāo)簽名
	prop屬性,指定校驗(yàn)規(guī)則中的
  -->
  <el-form-item label="賬戶" prop="account">
	<!-- v-model將值收集到哪個(gè)變量中 -->
	<el-input v-model="form.account" />
  </el-form-item>
  <el-form-item label="密碼">
	<el-input v-model="form.password" />
  </el-form-item>
  <el-button size="large" class="subBtn">點(diǎn)擊登錄</el-button>
</el-form>

演示效果

自定義校驗(yàn)規(guī)則

<script>中的規(guī)則中,數(shù)組中的每一個(gè)對(duì)象都是一個(gè)校驗(yàn)規(guī)則,我們只需要給一個(gè)對(duì)象給出validator()方法的實(shí)現(xiàn)即可:
該方法有三個(gè)參數(shù):

validator(rule, value, callback){
	// rule此條規(guī)則的描述信息
	// value表單中此字段的值
	// 回調(diào)函數(shù),通過此函數(shù)控制是否校驗(yàn)通過
}

看個(gè)例子

// 定義校驗(yàn)規(guī)則
const rules = reactive({
// 普通的校驗(yàn)規(guī)則
  account: [
    { required: true, message: '賬戶不能為空', trigger: 'blur' },
    { min: 6, max: 14, message: '用戶名長(zhǎng)度為6 - 14位' }
  ],
  password: [
  // 自定義校驗(yàn)規(guī)則
    {
      validator(rule, value, callback) {
        if (value[0] === '0') {
	      // 校驗(yàn)不通過
          return callback(new Error('密碼字段的第一位不能是0'))
        } else {
          // 校驗(yàn)通過
          callback()
        }
      }
    }
  ]
})

在模版中使用為字段使用此條校驗(yàn)規(guī)則

<el-form
  :model="form"
  :rules="rules"
>
  <!--
	label標(biāo)簽名
	prop屬性,指定校驗(yàn)規(guī)則中的
  -->
  <el-form-item label="賬戶" prop="account">
	<!-- v-model將值收集到哪個(gè)變量中 -->
	<el-input v-model="form.account" />
  </el-form-item>
  <el-form-item label="密碼" prop="password">
	<el-input v-model="form.password" />
  </el-form-item>
  <el-button size="large" class="subBtn">點(diǎn)擊登錄</el-button>
</el-form>

演示效果

表單統(tǒng)一校驗(yàn)

如果用戶什么都不輸入,直接點(diǎn)擊登錄,那么每個(gè)字段的校驗(yàn)規(guī)則是不生效的,因?yàn)榇俗侄芜€沒有輸入。
為了避免用戶在不操作表單的情況下,直接提交表單,可以在用戶點(diǎn)擊提交按鈕后,對(duì)所有的字段重新激活一次校驗(yàn)。
通過表單對(duì)象的一個(gè)方法validate()方法,對(duì)整個(gè)表單的所有內(nèi)容進(jìn)行一次驗(yàn)證。

form.validate(callback)

此方法接收一個(gè)回調(diào)函數(shù),回調(diào)函數(shù)的第一個(gè)參數(shù),是布爾類型,當(dāng)所有的校驗(yàn)規(guī)則都通過時(shí),此值是true,否則false
回調(diào)函數(shù)的第二個(gè)參數(shù)是校驗(yàn)未通過的所有字段的數(shù)組
在form表單中通過ref屬性標(biāo)識(shí)一下

<el-form ref="formRef">
</el-form>

<script>部分

// 獲取form表單引用
const formRef = ref(null)
// 當(dāng)點(diǎn)擊登錄按鈕時(shí)的函數(shù)
const submit = () => {
  // 獲取到真正的表單元素
  formRef.value.validate((isValid, invalidFields) => {
    if (isValid) {
      // 表單所有元素驗(yàn)證通過,可以提交了
      console.log('驗(yàn)證通過')
    } else {
      console.log(invalidFields)
      console.log('驗(yàn)證不通過,不能提交,請(qǐng)檢查')
    }
  })
}

到此這篇關(guān)于關(guān)于ElementPlus中的表單驗(yàn)證的文章就介紹到這了,更多相關(guān)ElementPlus表單驗(yàn)證內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue超出文本框顯示省略號(hào)鼠標(biāo)滑入顯示全部的實(shí)現(xiàn)方法

    Vue超出文本框顯示省略號(hào)鼠標(biāo)滑入顯示全部的實(shí)現(xiàn)方法

    在Vue項(xiàng)目中經(jīng)常需要處理文本內(nèi)容過長(zhǎng)的情況,這篇文章主要給大家介紹了關(guān)于Vue超出文本框顯示省略號(hào)鼠標(biāo)滑入顯示全部的實(shí)現(xiàn)方法,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-10-10
  • 在項(xiàng)目vue中使用echarts的操作步驟

    在項(xiàng)目vue中使用echarts的操作步驟

    這篇文章主要介紹了在項(xiàng)目vue中使用echarts的操作步驟,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • Vue實(shí)現(xiàn)路由跳轉(zhuǎn)的3種方式超詳細(xì)分解

    Vue實(shí)現(xiàn)路由跳轉(zhuǎn)的3種方式超詳細(xì)分解

    Vue.js是一款流行的前端JavaScript框架,它提供了多種方式來實(shí)現(xiàn)路由跳轉(zhuǎn),下面這篇文章主要給大家介紹了關(guān)于Vue實(shí)現(xiàn)路由跳轉(zhuǎn)的3種方式,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-12-12
  • Vue接入高德地圖的完整實(shí)例

    Vue接入高德地圖的完整實(shí)例

    近期在用vue做一個(gè)環(huán)保類的項(xiàng)目,要求使用高德地圖,下面這篇文章主要給大家介紹了關(guān)于Vue接入高德地圖的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-06-06
  • vue的index.html中獲取環(huán)境變量和業(yè)務(wù)判斷圖文詳解

    vue的index.html中獲取環(huán)境變量和業(yè)務(wù)判斷圖文詳解

    這篇文章主要給大家介紹了關(guān)于vue的index.html中獲取環(huán)境變量和業(yè)務(wù)判斷的相關(guān)資料,對(duì)vue來說index.html是一個(gè)總的入口文件,vue是單頁面應(yīng)用,掛在id為app的div下然后動(dòng)態(tài)渲染路由模板,需要的朋友可以參考下
    2023-09-09
  • Vue2源碼解析之自定義指令

    Vue2源碼解析之自定義指令

    自定義指令,其實(shí)就是在vue提供的鉤子中寫代碼,這篇文章將從源碼的角度,帶大家深入了解一下Vue2種自定義指令的實(shí)現(xiàn)與使用,需要的可以參考一下
    2023-05-05
  • 淺析Visual Studio Code斷點(diǎn)調(diào)試Vue

    淺析Visual Studio Code斷點(diǎn)調(diào)試Vue

    本篇文章給大家總結(jié)了Visual Studio Code斷點(diǎn)調(diào)試Vue的方法以及心得分享,需要的朋友參考學(xué)習(xí)下。
    2018-02-02
  • 常見的5種Vue組件通信方式總結(jié)

    常見的5種Vue組件通信方式總結(jié)

    在?Vue.js?中,組件通信是開發(fā)過程中非常重要的一部分,它涉及到不同組件之間的數(shù)據(jù)傳遞和交互,本文將介紹如何實(shí)現(xiàn)父子組件之間的有效通信,并盤點(diǎn)了常見的5種Vue組件通信方式總結(jié),需要的朋友可以參考下
    2024-03-03
  • vue中的h函數(shù)使用及說明

    vue中的h函數(shù)使用及說明

    這篇文章主要介紹了vue中的h函數(shù)使用及說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • Vue3造輪子之Typescript配置highlight過程

    Vue3造輪子之Typescript配置highlight過程

    這篇文章主要介紹了Vue3造輪子之Typescript配置highlight過程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-07-07

最新評(píng)論