溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

vue中resetFields重置初始值不生效如何解決

發(fā)布時(shí)間:2023-03-23 14:25:32 來源:億速云 閱讀:234 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹了vue中resetFields重置初始值不生效如何解決的相關(guān)知識(shí),內(nèi)容詳細(xì)易懂,操作簡單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇vue中resetFields重置初始值不生效如何解決文章都會(huì)有所收獲,下面我們一起來看看吧。

問題

最近在做項(xiàng)目的時(shí)候, dialog組件回調(diào)close里面 一般我都會(huì)加個(gè)resetFields 重置初始值和校驗(yàn)

其他地方都沒問題, 在table組件里面出問題了, 后來經(jīng)過監(jiān)聽vue tools, 查看到resetFields后, formData沒變, 最后也找到原因了.

解決

1、用 dialog【新增】、【修改】數(shù)據(jù)

2、先點(diǎn)擊了【修改】,彈出彈窗,此時(shí)彈窗的form表單已經(jīng)賦值

3、再點(diǎn)擊新增按鈕,此時(shí)調(diào)用resetFields()方法是沒有辦法使form清空的

如果直接只寫this.$refs.formRef.resetFields()

因?yàn)榫庉嫴僮魇怯袛?shù)據(jù)回顯的, 數(shù)據(jù)回顯是在mounted階段渲染上去的,

而 resetFields是將form表單重置到初始值,而這個(gè)初始值是form表單mounted后的值

結(jié)果就導(dǎo)致只能清空校驗(yàn), 不能重置表單到我們想要的初始值

所以直接this.$data.roleFrom=JSON.parse(JSON.stringify(this.$options.data().roleFrom))

深拷貝roleForm yeah! 完成

vue中resetFields重置初始值不生效如何解決

引申

 我的其他頁面為什么沒問題呢?  我后來去看了其他組件的dialog為什么數(shù)據(jù)回顯沒問題, 因?yàn)槠渌M件我用到了watch 根據(jù)id變化執(zhí)行渲染, 每次dialog close回調(diào)我都會(huì)主動(dòng)把id清空為空字符串, 正好那個(gè)接口id如果為空字符串也會(huì)發(fā)請(qǐng)求, 獲取的數(shù)據(jù)正好和回顯的值不對(duì)應(yīng), 所以就為空了。本質(zhì)上是重新發(fā)了請(qǐng)求,但正好因?yàn)閿?shù)據(jù)不對(duì)應(yīng)不顯示,造成了添加操作時(shí)數(shù)據(jù)為空的正確表象。

 總的來說還是不嚴(yán)謹(jǐn),  我這里要修改代碼,watch這里加個(gè)if的意思是每次關(guān)閉會(huì)重置,但是打開不用重置。

①  子組件 watch if newVal===" " 上面的表單重置方法(這里空字符串我特意加了個(gè)空格看的清楚點(diǎn), 實(shí)際重置不用加空格)

②  父組件dialog close回調(diào)里面添加一條 isEdit=false  防止子組件watch id變化為空字符時(shí)重復(fù)發(fā)ajax

vue中resetFields重置初始值不生效如何解決

vue中resetFields重置初始值不生效如何解決

加個(gè)補(bǔ)充

還有一點(diǎn)就是如果每次獲取都是用ajax去獲取數(shù)據(jù), 那獲取的也是新地址對(duì)象, 只是因?yàn)槲也糠謹(jǐn)?shù)據(jù)用了本地已存在的引用數(shù)據(jù), 所以才會(huì)有這種情況, 所以大家用引用數(shù)據(jù)一定要注意, 如果發(fā)現(xiàn)有關(guān)聯(lián)關(guān)系, 且影響業(yè)務(wù), 都深拷貝一份吧

關(guān)于“vue中resetFields重置初始值不生效如何解決”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對(duì)“vue中resetFields重置初始值不生效如何解決”知識(shí)都有一定的了解,大家如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI