1. 程式人生 > 程式設計 >Vue之ElementUI Form表單校驗

Vue之ElementUI Form表單校驗

表單校驗是前端開發過程中最常用到的功能之一,根據個人的工作經驗總結在此對錶單校驗功能的基礎用法進行整理說明。

以下是form的demo

el-form :model="dynamicValidateForm" ref="dynamicValidateForm" label-width="100px" class="demo-dynamic">
  <el-form-item
    prop="email"
    label="郵箱"
    :rules="[
      { required: true,message: '請輸入郵箱地址',trigger: 'blur' },{ type: 'email',message: '請輸入正確的郵箱地址',trigger: ['blur',www.cppcns.com
'change'] } ]" > <el-input v-model="dynamicValidateForm.email"></el-input> </el-form-item> <el-form-item v-for="(domain,index) in dynamicValidateForm.domains" :label="'域名' + index" :key="domain.key" :prop="'domains.' + index + '.value'" :rules="{ required: true,message: '域名不能為空',trigger: 'blur' }" > <el-input v-model="domain.value"></el-input><el-button @click.prevent="removeDomain(domain)">刪除</el-button> </el-form-item> <el-form-item> <el-button type="primary" @click="submitForm('dynamicValidateForm')">提交</el-button> <el-button @click="addDomain">新增域名</el-button> <el-button @click="resetForm('dynamicValidateForm')">重置</el-button> </el-form-item> </el-form> <script> export default { data() { return { dynamicValidateForm: { domains: [{ value: '' }],email: '' } }; },methods: { submitForm(formName) { this.$refs[formName].validate((valid) => { if (valid) { alert('submit!'); } else { console.log('error submit!!');
retuwww.cppcns.comrn false; } }); },resetForm(formName) { this.$refs[formName].resetFields(); },removeDomain(item) { var index = this.dynamicValidateForm.domains.indexOf(item) if (index !== -1) { this.dynamicValidateForm.domains.splice(index,1) } },addDomain() { this.dynamicValidateForm.domains.push({ value: '',key: Date.now() }); } } } </script>

Vue之ElementUI Form表單校驗

首先對el-form標籤中的幾個關鍵屬性進行說明

  • ref: 當前表單的唯一標識
  • model: 表單繫結的物件
  • rules: 欄位校驗規則

rules欄位用來定義各個欄位具體的校驗規則,用法請查閱開篇的demo示例,其中required標識欄位是否必填,message為校驗提示語,trigger為單個校驗觸發方式;也可以通過validator欄位自ozLaTeH定義校驗規則,方法validateProductName中對商品名稱做了判空及長度校驗,需要注意的是所有的條件分支都要做callback處理,否則校驗可能會導致異常。

1、重置表單

呼叫表單重置方法this.$refs.dynamicValidateForm.resetFields()實現。

當然像datetimerange型別的日期控制元件是無法通過該方法進行重置,必須手動重置繫結的欄位。

2、 清除校驗提示語

呼叫方法this.$refs.dynamicValidateForm.clearValidate()實現。

如果僅需要清除單個控制元件的提示語,只要把該控制元件對應的prop屬性值作為引數傳入即可。

還有另外一種方式就是在該控制元件對應的el-form-item標籤中增加ref屬性值,然後呼叫clearValidate方法。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。