Element-UI清空表單及驗(yàn)證不生效的問題解決
問題描述
由于我將編輯與新增時(shí),表單使用的是同一個(gè)data中的數(shù)據(jù),這就導(dǎo)致出現(xiàn)了我點(diǎn)擊了編輯后,再次點(diǎn)擊新增時(shí),出現(xiàn)了數(shù)據(jù)依舊是剛才編輯表單中的數(shù)據(jù)。
解決辦法
嘗試一(不推薦)
通過 手動(dòng)給表單中的字段賦值
,期初時(shí),能達(dá)到清除表單的效果,但是又出現(xiàn)了新的問題。表單驗(yàn)證不通過。在一打開對(duì)話框時(shí),就默認(rèn)觸發(fā)了表單的驗(yàn)證規(guī)則。
查閱Element-UI官方文檔,可以發(fā)現(xiàn)有有清除驗(yàn)證的方法 clearValidate
。
只需將該方法寫上,即可。
if (this.$refs.studentInfoRef) { this.$nextTick(() => { this.$refs.studentInfoRef.clearValidate(); }); }
嘗試二(推薦)
查閱Element-UI官方文檔可以發(fā)現(xiàn),官方提供了一個(gè)重置表單的 resetFields()
方法。
但發(fā)現(xiàn)調(diào)用Element-UI官方提供的 resetFields()
方法并未生效。甚至還出現(xiàn)了以下錯(cuò)誤 Error in v-on handler: "TypeError: Cannot read properties of undefined (reading 'resetFields')"
。不急,有解決辦法。
出現(xiàn)上述情況,嘗試用網(wǎng)絡(luò)上普遍認(rèn)為的錯(cuò)誤(很可能是起作用的生命周期不一致)解決辦法來解決。這時(shí)我們先將調(diào)用這個(gè)方法放到 this.$nextTick
中。
但是問題依舊存在。
閱讀這個(gè)問題,可以知道,說的是這個(gè)未定義。好吧,可能還是生效的時(shí)間不對(duì),那我就加一個(gè)條件判斷,讓這個(gè)存在時(shí)在去執(zhí)行。
if (this.$refs.studentInfoRef) { this.$nextTick(() => { this.$refs.studentInfoRef.resetFields(); }); }
發(fā)現(xiàn)問題得到了解決。這時(shí)有可能是瀏覽器緩存的問題,還需要做的操作是需要再表單上添加 @close
方法。在關(guān)閉時(shí)清除清除表單,在打開時(shí)清除表單驗(yàn)證,這個(gè)比較靠譜的一個(gè)解決辦法。
總結(jié)
在使用Element-UI重置表單的方式時(shí),一定要記住,表單中的prop屬性不要漏掉。
在查看方法使用時(shí),并未提到prop這個(gè)屬性,但繼續(xù)往下閱讀文檔,就會(huì)發(fā)現(xiàn),這個(gè)屬性是必須的。
注意prop屬性值需要與model中的值一致。
注意: 在 this.$refs.studentInfoRef.resetFields();
這一句話中, studentInfoRef
需要與表單中的ref一致,且不能去其他的ref重名。
到此這篇關(guān)于Element-UI清空表單及驗(yàn)證不生效的問題解決的文章就介紹到這了,更多相關(guān)Element清空表單及驗(yàn)證不生效內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- element ui提交表單返回成功后自動(dòng)清空表單的值的實(shí)現(xiàn)代碼
- 詳解element-ui中表單驗(yàn)證的三種方式
- Vue ElementUI之Form表單驗(yàn)證遇到的問題
- element 結(jié)合vue 在表單驗(yàn)證時(shí)有值卻提示錯(cuò)誤的解決辦法
- Element UI 自定義正則表達(dá)式驗(yàn)證方法
- vue中使用element-ui進(jìn)行表單驗(yàn)證的實(shí)例代碼
- vue elementui form表單驗(yàn)證的實(shí)現(xiàn)
- 解決vue+ element ui 表單驗(yàn)證有值但驗(yàn)證失敗問題
相關(guān)文章
vue-router實(shí)現(xiàn)嵌套路由的講解
今天小編就為大家分享一篇關(guān)于vue-router實(shí)現(xiàn)嵌套路由的講解,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-01-01vue中使用極驗(yàn)驗(yàn)證碼的方法(附demo)
這篇文章主要介紹了vue中使用極驗(yàn)驗(yàn)證碼的方法(附demo)本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-12-12Vue+Element ui實(shí)現(xiàn)樹形控件右鍵菜單
這篇文章主要為大家詳細(xì)介紹了Vue+Element ui實(shí)現(xiàn)樹形控件右鍵菜單,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07vue實(shí)現(xiàn)無縫滾動(dòng)手摸手教程
這篇文章主要為大家介紹了vue實(shí)現(xiàn)無縫滾動(dòng)手摸手教程示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03在Vue3和TypeScript中大文件分片上傳的實(shí)現(xiàn)與優(yōu)化
本文介紹在 Vue 3 和 TypeScript 環(huán)境下大文件分片上傳的實(shí)現(xiàn)與優(yōu)化,包括項(xiàng)目前后端技術(shù)棧,前端的文件切片、并發(fā)上傳、計(jì)算 Hash、斷點(diǎn)續(xù)傳和用戶體驗(yàn)優(yōu)化,后端的文件接收存儲(chǔ)、切片合并、異常處理與日志記錄,還提及遇到的問題及解決方案,總結(jié)了此方式的優(yōu)勢(shì)和重要性2025-01-01關(guān)于nuxt?store中保存localstorage的問題
這篇文章主要介紹了關(guān)于nuxt?store中保存localstorage的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10