欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue中resetFields重置初始值不生效的原因詳解

 更新時(shí)間:2023年03月23日 11:02:19   作者:張大牛Zz  
resetFields 對(duì)整個(gè)表單進(jìn)行重置,將所有字段值重置為空并移除校驗(yàn)結(jié)果,下面這篇文章主要給大家介紹了關(guān)于vue中resetFields重置初始值不生效的原因的相關(guān)資料,需要的朋友可以參考下

問題

最近在做項(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! 完成

c607595b796bc6fbce3be172ec89530b.png

引申

 我的其他頁面為什么沒問題呢?  我后來去看了其他組件的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

加個(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ù), 都深拷貝一份吧

總結(jié)

到此這篇關(guān)于vue中resetFields重置初始值不生效的原因的文章就介紹到這了,更多相關(guān)resetFields重置初始值不生效內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue動(dòng)態(tài)綁定組件子父組件多表單驗(yàn)證功能的實(shí)現(xiàn)代碼

    vue動(dòng)態(tài)綁定組件子父組件多表單驗(yàn)證功能的實(shí)現(xiàn)代碼

    這篇文章主要介紹了vue動(dòng)態(tài)綁定組件子父組件多表單驗(yàn)證功能的實(shí)現(xiàn)代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2018-05-05
  • Vue 與 Vuex 的第一次接觸遇到的坑

    Vue 與 Vuex 的第一次接觸遇到的坑

    在 Vue.js 的項(xiàng)目中,如果項(xiàng)目結(jié)構(gòu)簡(jiǎn)單, 父子組件之間的數(shù)據(jù)傳遞可以使用 props 或者 $emit 等方式,如果是大型項(xiàng)目,很多時(shí)候都需要在子組件之間傳遞數(shù)據(jù),使用vue的狀態(tài)管理工具vuex很好的解決
    2018-08-08
  • Vue中子組件向父組件傳值$emit、.sync的案例詳解

    Vue中子組件向父組件傳值$emit、.sync的案例詳解

    這篇文章主要介紹了Vue中子組件向父組件傳值$emit、.sync的方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-09-09
  • Element?UI?Upload?組件上傳圖片可刪除、預(yù)覽功能

    Element?UI?Upload?組件上傳圖片可刪除、預(yù)覽功能

    這篇文章主要介紹了Element?UI?Upload?組件?上傳圖片可刪除、預(yù)覽,設(shè)置只允許上傳單張?/?多張圖片的操作,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-11-11
  • Vue頁面反復(fù)刷新的常見問題及解決方案

    Vue頁面反復(fù)刷新的常見問題及解決方案

    Vue.js 是一個(gè)流行的前端框架,旨在通過其響應(yīng)式的數(shù)據(jù)綁定和組件化的開發(fā)模式簡(jiǎn)化開發(fā),然而,在開發(fā) Vue.js 應(yīng)用時(shí),頁面反復(fù)刷新的問題可能會(huì)對(duì)用戶體驗(yàn)和開發(fā)效率產(chǎn)生負(fù)面影響,本文將深入探討 Vue 頁面反復(fù)刷新的常見原因,并提供詳細(xì)的解決方案
    2024-09-09
  • Vue不能watch數(shù)組和對(duì)象變化解決方案

    Vue不能watch數(shù)組和對(duì)象變化解決方案

    這篇文章主要為大家介紹了Vue不能watch數(shù)組和對(duì)象變化解決方案示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • vue引入swiper插件的使用實(shí)例

    vue引入swiper插件的使用實(shí)例

    本篇文章主要介紹了vue引入swiper插件的使用實(shí)例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-07-07
  • 基于vue2框架的機(jī)器人自動(dòng)回復(fù)mini-project實(shí)例代碼

    基于vue2框架的機(jī)器人自動(dòng)回復(fù)mini-project實(shí)例代碼

    本篇文章主要介紹了基于vue2框架的機(jī)器人自動(dòng)回復(fù)mini-project實(shí)例代碼,具有一定的參考價(jià)值,有興趣的可以了解一下
    2017-06-06
  • Vue Router中應(yīng)用中間件的方法

    Vue Router中應(yīng)用中間件的方法

    這篇文章主要介紹了Vue Router中應(yīng)用中間件的方法,文中講解非常細(xì)致,幫助大家更好的理解和學(xué)習(xí)vue router,感興趣的朋友可以了解下
    2020-08-08
  • Vue實(shí)現(xiàn)全局菜單搜索框的示例

    Vue實(shí)現(xiàn)全局菜單搜索框的示例

    本文主要介紹了Vue實(shí)現(xiàn)全局菜單搜索框的示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-02-02

最新評(píng)論