vue中resetFields重置初始值不生效的原因詳解
問題
最近在做項目的時候, dialog組件回調(diào)close里面 一般我都會加個resetFields 重置初始值和校驗
其他地方都沒問題, 在table組件里面出問題了, 后來經(jīng)過監(jiān)聽vue tools, 查看到resetFields后, formData沒變, 最后也找到原因了.
解決
1、用 dialog【新增】、【修改】數(shù)據(jù)
2、先點擊了【修改】,彈出彈窗,此時彈窗的form表單已經(jīng)賦值
3、再點擊新增按鈕,此時調(diào)用resetFields()方法是沒有辦法使form清空的
如果直接只寫this.$refs.formRef.resetFields()
因為編輯操作是有數(shù)據(jù)回顯的, 數(shù)據(jù)回顯是在mounted階段渲染上去的,
而 resetFields是將form表單重置到初始值,而這個初始值是form表單mounted后的值
結(jié)果就導(dǎo)致只能清空校驗, 不能重置表單到我們想要的初始值
所以直接this.$data.roleFrom=JSON.parse(JSON.stringify(this.$options.data().roleFrom))
深拷貝roleForm yeah! 完成

引申
我的其他頁面為什么沒問題呢? 我后來去看了其他組件的dialog為什么數(shù)據(jù)回顯沒問題, 因為其他組件我用到了watch 根據(jù)id變化執(zhí)行渲染, 每次dialog close回調(diào)我都會主動把id清空為空字符串, 正好那個接口id如果為空字符串也會發(fā)請求, 獲取的數(shù)據(jù)正好和回顯的值不對應(yīng), 所以就為空了。本質(zhì)上是重新發(fā)了請求,但正好因為數(shù)據(jù)不對應(yīng)不顯示,造成了添加操作時數(shù)據(jù)為空的正確表象。
總的來說還是不嚴(yán)謹(jǐn), 我這里要修改代碼,watch這里加個if的意思是每次關(guān)閉會重置,但是打開不用重置。
① 子組件 watch if newVal===" " 上面的表單重置方法(這里空字符串我特意加了個空格看的清楚點, 實際重置不用加空格)
② 父組件dialog close回調(diào)里面添加一條 isEdit=false 防止子組件watch id變化為空字符時重復(fù)發(fā)ajax


加個補充
還有一點就是如果每次獲取都是用ajax去獲取數(shù)據(jù), 那獲取的也是新地址對象, 只是因為我部分?jǐn)?shù)據(jù)用了本地已存在的引用數(shù)據(jù), 所以才會有這種情況, 所以大家用引用數(shù)據(jù)一定要注意, 如果發(fā)現(xiàn)有關(guān)聯(lián)關(guān)系, 且影響業(yè)務(wù), 都深拷貝一份吧
總結(jié)
到此這篇關(guān)于vue中resetFields重置初始值不生效的原因的文章就介紹到這了,更多相關(guān)resetFields重置初始值不生效內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue與bootstrap實現(xiàn)時間選擇器的示例代碼
本篇文章主要介紹了vue與bootstrap實現(xiàn)時間選擇器的示例代碼,非常具有實用價值,需要的朋友可以參考下2017-08-08
利用Vue Native構(gòu)建移動應(yīng)用的全過程記錄
VueNative是一個使用JavaScript構(gòu)建跨平臺原生移動應(yīng)用程序的框架m這篇文章主要給大家介紹了關(guān)于如何利用Vue Native構(gòu)建移動應(yīng)用的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2021-08-08
vue3實現(xiàn)動態(tài)側(cè)邊菜單欄的幾種方式簡單總結(jié)
在做開發(fā)中都會遇到的需求,每個用戶的權(quán)限是不一樣的,那他可以訪問的頁面(路由)可以操作的菜單選項是不一樣的,如果由后端控制,我們前端需要去實現(xiàn)動態(tài)路由,動態(tài)渲染側(cè)邊菜單欄,這篇文章主要給大家介紹了關(guān)于vue3實現(xiàn)動態(tài)側(cè)邊菜單欄的幾種方式,需要的朋友可以參考下2024-02-02
Vue實現(xiàn)頁面的局部刷新(router-view頁面刷新)
本文主要介紹了Vue實現(xiàn)頁面的局部刷新(router-view頁面刷新),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-12-12

