Vue3父子組件表單滾動(dòng)到校驗(yàn)錯(cuò)誤的位置實(shí)現(xiàn)過(guò)程
更新時(shí)間:2025年07月30日 09:00:38 作者:滿
文章介紹了如何在包含父表單和多個(gè)子表單的場(chǎng)景中,通過(guò)滾動(dòng)方法實(shí)現(xiàn)提交時(shí)的校驗(yàn)機(jī)制,確保數(shù)據(jù)完整性與用戶操作體驗(yàn)
Vue3父子組件表單滾動(dòng)到校驗(yàn)錯(cuò)誤的位置
表單包括父表單、多個(gè)子表單
<div class="scollContainer">
<div class="container">
<ProjectInfo ref="projectInfoRef" v-model="formData" :form-rules="rules"></ProjectInfo>
<div class="content" style="position: relative">
<group-title>子債信息</group-title>
<div v-if="!detailFlag" style="position: absolute; top: 8px; right: 10px">
<el-button type="primary" @click="addChildBond">添加</el-button>
<el-button v-if="formData.mdmDcmSubStructurizeInfoList.length > 1" @click="delChildBond"
>刪除</el-button
>
</div>
<div>
<group-title>子債信息</group-title>
<childBondInfo
v-for="(item, index) in formData.mdmDcmSubStructurizeInfoList"
:ref="setChildRef"
:key="index"
v-model="formData.mdmDcmSubStructurizeInfoList[index]"
:form-rules="rules"
:index="index"
:is-involve-clause="formData.isInvolveInvestorProtectionClause"
></childBondInfo>
</div>
</div>
</div>
</div>滾動(dòng)方法
const scrollToFirstError = (formRef) => {
// 獲取第一個(gè)帶有錯(cuò)誤信息的表單字段
const firstErrorField = document.querySelector('.el-form-item.is-error');
if (firstErrorField) {
// 平滑滾動(dòng)到該字段
firstErrorField.scrollIntoView({
behavior: 'smooth',
block: 'center',
});
}
};提交時(shí)校驗(yàn)
// 定義子組件ref
const childFormRefs = ref([]);
const setChildRef = (el) => {
if (el) {
childFormRefs.value.push(el);
}
};
const projectInfoRef = ref();
const vForm = ref();
//提交方法里校驗(yàn)
//validateProjectForm子組件提供的校驗(yàn)方法
let projectValid = projectInfoRef.value
? await projectInfoRef.value.validateProjectForm()
: { isValid: true };
// 校驗(yàn)所有子表單
//validateForm子組件提供的校驗(yàn)方法
const childValids = await Promise.all(childFormRefs.value.map((child) => child.validateForm()));
// // 檢查子表單校驗(yàn)結(jié)果
const invalidForms = childValids.filter((result) => !result.isValid);
const formValid = await instance.proxy.$refs.vForm.validate((valid) => {
return valid;
});
console.log(projectValid.isValid, 'kkk');
if (!projectValid?.isValid) {
scrollToFirstError(projectInfoRef.value); //校驗(yàn)不通過(guò),滾動(dòng)到第一個(gè)表單錯(cuò)誤位置
} else if (invalidForms.length > 0) {
const firstInvalidIndex = childValids.findIndex((result) => !result.isValid);
scrollToFirstError(childFormRefs.value[firstInvalidIndex]); //校驗(yàn)不通過(guò),滾動(dòng)到多個(gè)子表單第一個(gè)錯(cuò)誤位置
} else if (!formValid) {
scrollToFirstError(instance.proxy.$refs.vForm);
}
if (!projectValid?.isValid || invalidForms.length > 0 || !formValid) {
return;
}總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
electron + vue項(xiàng)目實(shí)現(xiàn)打印小票功能及實(shí)現(xiàn)代碼
這篇文章主要介紹了electron + vue項(xiàng)目實(shí)現(xiàn)打印小票功能,需要的朋友可以參考下2018-11-11
詳解vue+vuex+koa2開(kāi)發(fā)環(huán)境搭建及示例開(kāi)發(fā)
本篇文章主要介紹了詳解vue + vuex + koa2開(kāi)發(fā)環(huán)境搭建及示例開(kāi)發(fā),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-01-01
淺談vue單一組件下動(dòng)態(tài)修改數(shù)據(jù)時(shí)的全部重渲染
下面小編就為大家分享一篇淺談vue單一組件下動(dòng)態(tài)修改數(shù)據(jù)時(shí)的全部重渲染,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-03-03
vue3+vite兼容低版本的白屏問(wèn)題詳解(安卓7/ios11)
這篇文章主要給大家介紹了關(guān)于vue3+vite兼容低版本的白屏問(wèn)題的相關(guān)資料,還給大家介紹了vue打包項(xiàng)目以后白屏和圖片加載不出來(lái)問(wèn)題的解決方法,需要的朋友可以參考下2022-12-12
Vue3中動(dòng)態(tài)修改樣式與級(jí)聯(lián)樣式優(yōu)先順序圖文詳解
在項(xiàng)目中,我們時(shí)常會(huì)遇到動(dòng)態(tài)的去綁定操作切換不同的CSS樣式,下面這篇文章主要給大家介紹了關(guān)于Vue3中動(dòng)態(tài)修改樣式與級(jí)聯(lián)樣式優(yōu)先順序的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-04-04
Vue使用xlsx組件輕松實(shí)現(xiàn)Excel導(dǎo)出的完整代碼
在日常開(kāi)發(fā)中,Excel導(dǎo)出是管理系統(tǒng)的高頻需求,本文手把手教你如何在Vue項(xiàng)目中快速實(shí)現(xiàn)Excel導(dǎo)出功能,支持復(fù)雜表格樣式,并附贈(zèng)性能優(yōu)化方案,需要的朋友可以參考下2025-05-05

