vue獲取el-form的整體驗(yàn)證狀態(tài)
el-form-item 的驗(yàn)證狀態(tài)在
validateState屬性中,該屬性的值, 默認(rèn)為:空字符串,驗(yàn)證通過為success, 驗(yàn)證失敗為error
如果需要在一開始就要通過表單數(shù)據(jù)的驗(yàn)證狀態(tài),決定操作按鈕(如:保存)是否禁用,那么需要注意兩點(diǎn):
- 需要通過如下方式獲取驗(yàn)證狀態(tài)
// this.$refs.validateForm 表示一個(gè)el-form // this.$refs.validateForm.fields 表示所有el-form-item // validateStateArr結(jié)果大概會是:['','success','error'] const validateStateArr = this.$refs.validateForm.fields.map((item) => { return item.validateState; }) - 有兩種情況表示驗(yàn)證不通過:
- A情況:el-form-item的validateState為
error. - B情況:el-form-item存在驗(yàn)證規(guī)則,但validateState為空字符串.
- A情況:el-form-item的validateState為
示例代碼:

<template>
<div>
<el-form
ref="validateForm"
:model="formData"
@validate="onValidate"
:status-icon="true"
>
<el-form-item label="姓名" :rules="ruleObj.name" prop="name">
<el-input v-model="formData.name"></el-input>
</el-form-item>
<el-form-item label="狀態(tài)" :rules="ruleObj.status" prop="status">
<el-select v-model="formData.status">
<el-option :value="1" label="啟用"></el-option>
<el-option :value="2" label="禁用"></el-option>
</el-select>
</el-form-item>
<el-form-item label="賬號" :rules="ruleObj.account" prop="account">
<el-input v-model="formData.account"></el-input>
</el-form-item>
<el-form-item
label="開始日期"
:rules="ruleObj.beginDate"
prop="beginDate"
>
<el-date-picker
type="date"
v-model="formData.beginDate"
placement="bottom-start"
value-format="yyyy-MM-dd"
@change="(values) => onChange(values, 'endDate')"
></el-date-picker>
</el-form-item>
<el-form-item label="結(jié)束日期" :rules="ruleObj.endDate" prop="endDate">
<el-date-picker
type="date"
v-model="formData.endDate"
placement="bottom-start"
value-format="yyyy-MM-dd"
@change="(values) => onChange(values, 'beginDate')"
></el-date-picker>
</el-form-item>
</el-form>
<el-button type="primary" :disabled="!validatePass" @click="onSave">
保存
</el-button>
</div>
</template>
<script>
export default {
name: "StyleTextPage",
data() {
return {
formData: {
status: null,
name: null,
account: null,
endDate: null,
beginDate: null,
},
// 表單是否整體通過驗(yàn)證
validatePass: false,
// 賬號ajax是否正處于驗(yàn)證中
accountAjaxValidating: false,
ruleObj: {
endDate: [
{
validator: (rule, value, callback) => {
if (this.formData.beginDate === this.formData.endDate) {
return callback(new Error("開始日期不能等于結(jié)束日期"));
} else {
// 如果即在endDate驗(yàn)證成功時(shí),立即觸發(fā)beginDate的驗(yàn)證,且在beginDate驗(yàn)證成功時(shí),立即觸發(fā)endDate的驗(yàn)證會導(dǎo)致驗(yàn)證死循環(huán),因此這種驗(yàn)證,只能在change事件中觸發(fā)
// this.$nextTick(() => {
// this.$refs.validateForm.validateField("beginDate");
// });
return callback();
}
},
trigger: "change",
},
],
beginDate: [
{
validator: (rule, value, callback) => {
if (this.formData.beginDate === this.formData.endDate) {
return callback(new Error("開始日期不能等于結(jié)束日期"));
} else {
// 如果即在beginDate驗(yàn)證成功時(shí),立即觸發(fā)endDate的驗(yàn)證,且在endDate驗(yàn)證成功時(shí),立即觸發(fā)beginDate的驗(yàn)證會導(dǎo)致驗(yàn)證死循環(huán),因此這種驗(yàn)證,只能在change事件中觸發(fā)
// this.$nextTick(() => {
// this.$refs.validateForm.validateField("endDate");
// });
return callback();
}
},
trigger: "change",
},
{ required: true, message: "必填", trigger: "change" },
],
name: [],
account: [
{ required: true, message: "必填" },
{
validator: (rule, value, callback) => {
console.log("自定義賬號校驗(yàn)");
this.accountAjaxValidating = true;
// 進(jìn)入賬號自定義驗(yàn)證方法,則將表單設(shè)置為驗(yàn)證不通過(用來保證setTimeout休眠期間,保存按鈕是不可用的),最中是否通過由setTimeout的結(jié)果決定
this.validatePass = false;
setTimeout(() => {
console.log("獲取到驗(yàn)證結(jié)果");
this.accountAjaxValidating = false;
if (value === "111") {
return callback(new Error("賬號已存在"));
} else {
return callback();
}
}, 2000);
},
trigger: "blur",
},
],
status: [{ required: true, message: "必填" }],
},
};
},
mounted() {
console.log(this.$refs.validateForm.fields);
this.updateFormValidateStatus();
},
methods: {
onChange(val, relValidateField) {
console.log(val, relValidateField);
this.$refs.validateForm.validateField(relValidateField);
},
updateFormValidateStatus() {
let validateStateArr = [];
if (this.$refs.validateForm) {
validateStateArr = this.$refs.validateForm.fields.map((item) => {
if (item.validateState) {
return item.validateState;
} else if (item.rules && item.rules.length > 0) {
return "error";
} else {
return "success";
}
});
}
this.validatePass =
!this.accountAjaxValidating &&
validateStateArr.find((item) => item === "error") !== "error";
},
onValidate(...args) {
console.log("args", args);
this.updateFormValidateStatus();
},
async onSave() {
try {
await this.$refs.validateForm.validate();
} catch (e) {
console.error(e);
}
},
},
};
</script>
<style scoped></style>到此這篇關(guān)于vue獲取el-form的整體驗(yàn)證狀態(tài)的文章就介紹到這了,更多相關(guān)vue獲取el-form的整體驗(yàn)證狀態(tài)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue2路由方式--嵌套路由實(shí)現(xiàn)方法分析
這篇文章主要介紹了vue2嵌套路由實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了vue2嵌套路由基本實(shí)現(xiàn)方法與操作注意事項(xiàng),需要的朋友可以參考下2020-03-03
vue-cli的webpack模板項(xiàng)目配置文件分析
本篇文章主要對vue-cli的webpack模板項(xiàng)目配置文件進(jìn)行分析。具有很好的參考價(jià)值。下面跟著小編一起來看下吧2017-04-04
利用Vue.js實(shí)現(xiàn)checkbox的全選反選效果
最近用vue做了兩個(gè)項(xiàng)目,都需要實(shí)現(xiàn)全選反選的功能,所以想著記錄下分享給大家,方便自己或者有需要的朋友們參考講學(xué)習(xí),所以下面這篇文章主要介紹了利用Vue.js實(shí)現(xiàn)checkbox的全選反選效果,需要的朋友可以一起來學(xué)習(xí)學(xué)習(xí)。2017-01-01
vue3.0實(shí)現(xiàn)復(fù)選框組件的封裝
這篇文章主要為大家詳細(xì)介紹了vue3.0實(shí)現(xiàn)復(fù)選框組件的封裝代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
vuex刷新之后數(shù)據(jù)丟失,數(shù)據(jù)持久化,vuex-persistedstate問題
這篇文章主要介紹了vuex刷新之后數(shù)據(jù)丟失,數(shù)據(jù)持久化,vuex-persistedstate問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03
Vue導(dǎo)出頁面為PDF格式的實(shí)現(xiàn)思路
這篇文章主要介紹了Vue導(dǎo)出頁面為PDF格式的實(shí)現(xiàn)思路,其實(shí)思路也很簡單,就是將頁面轉(zhuǎn)換成圖片格式.然后通過圖片的base64碼.生成PDF..感興趣的朋友跟隨腳本之家小編一起看看吧2018-07-07

