Vue之ElementUI Form表單校驗(yàn)
表單校驗(yàn)是前端開發(fā)過(guò)程中最常用到的功能之一,根據(jù)個(gè)人的工作經(jīng)驗(yàn)總結(jié)在此對(duì)表單校驗(yàn)功能的基礎(chǔ)用法進(jìn)行整理說(shuō)明。
以下是form的demo
el-form :model="dynamicValidateForm" ref="dynamicValidateForm" label-width="100px" class="demo-dynamic"> <el-form-item prop="email" label="郵箱" :rules="[ { required: true, message: '請(qǐng)輸入郵箱地址', trigger: 'blur' }, { type: 'email', message: '請(qǐng)輸入正確的郵箱地址', trigger: ['blur', '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!!'); return 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>
首先對(duì)el-form標(biāo)簽中的幾個(gè)關(guān)鍵屬性進(jìn)行說(shuō)明
- ref: 當(dāng)前表單的唯一標(biāo)識(shí)
- model: 表單綁定的對(duì)象
- rules: 字段校驗(yàn)規(guī)則
rules字段用來(lái)定義各個(gè)字段具體的校驗(yàn)規(guī)則,用法請(qǐng)查閱開篇的demo示例,其中required標(biāo)識(shí)字段是否必填,message為校驗(yàn)提示語(yǔ),trigger為單個(gè)校驗(yàn)觸發(fā)方式;也可以通過(guò)validator字段自定義校驗(yàn)規(guī)則,方法validateProductName中對(duì)商品名稱做了判空及長(zhǎng)度校驗(yàn),需要注意的是所有的條件分支都要做callback處理,否則校驗(yàn)可能會(huì)導(dǎo)致異常。
1、重置表單
調(diào)用表單重置方法this.$refs.dynamicValidateForm.resetFields()實(shí)現(xiàn)。
當(dāng)然像datetimerange類型的日期控件是無(wú)法通過(guò)該方法進(jìn)行重置,必須手動(dòng)重置綁定的字段。
2、 清除校驗(yàn)提示語(yǔ)
調(diào)用方法this.$refs.dynamicValidateForm.clearValidate()實(shí)現(xiàn)。
如果僅需要清除單個(gè)控件的提示語(yǔ),只要把該控件對(duì)應(yīng)的prop屬性值作為參數(shù)傳入即可。
還有另外一種方式就是在該控件對(duì)應(yīng)的el-form-item標(biāo)簽中增加ref屬性值,然后調(diào)用clearValidate方法。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- vue+elementUI多表單同時(shí)提交及表單校驗(yàn)最新解決方案
- v-if 導(dǎo)致 elementui 表單校驗(yàn)失效問(wèn)題解決方案
- Elementui?el-input輸入框校驗(yàn)及表單校驗(yàn)實(shí)例代碼
- elementUI動(dòng)態(tài)嵌套el-form表單校驗(yàn)舉例詳解
- vue elementUI 表單校驗(yàn)的實(shí)現(xiàn)代碼(多層嵌套)
- vue elementUI 表單校驗(yàn)功能之?dāng)?shù)組多層嵌套
- 使用elementUI表單校驗(yàn)函數(shù)validate需要注意的坑及解決
相關(guān)文章
vue中重定向redirect:‘/index‘,不顯示問(wèn)題、跳轉(zhuǎn)出錯(cuò)的完美解決
這篇文章主要介紹了vue中重定向redirect:‘/index‘,不顯示問(wèn)題、跳轉(zhuǎn)出錯(cuò)的完美解決方案,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2020-09-09Vue 應(yīng)用中結(jié)合vux使用微信 jssdk的方法
今天小編就為大家分享一篇Vue 應(yīng)用中結(jié)合vux使用微信 jssdk的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-08-08解決vue3項(xiàng)目中el-menu不兼容SSR問(wèn)題
這篇文章主要介紹了解決vue3項(xiàng)目中el-menu不兼容SSR問(wèn)題,需要的朋友可以參考下2023-12-12Vue如何實(shí)現(xiàn)分批加載數(shù)據(jù)
這篇文章主要介紹了Vue如何實(shí)現(xiàn)分批加載數(shù)據(jù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04解決vue項(xiàng)目運(yùn)行npm run serve報(bào)錯(cuò)的問(wèn)題
這篇文章主要介紹了解決vue項(xiàng)目運(yùn)行npm run serve報(bào)錯(cuò)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-10-10手把手教你創(chuàng)建vue3項(xiàng)目的最佳方式
如今的Vue3已經(jīng)勢(shì)不可擋,當(dāng)然搭建一個(gè)全新的Vue3項(xiàng)目也有了全新的方式,下面這篇文章主要給大家介紹了關(guān)于如何手把手教你創(chuàng)建vue3項(xiàng)目的最佳方式,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-11-11