Vue中關(guān)閉彈窗組件時銷毀并隱藏操作
背景:在dialog彈窗組件中執(zhí)行mounted鉤子,將數(shù)據(jù)初始化,等取消關(guān)閉彈窗后,發(fā)現(xiàn)mounted鉤子不執(zhí)行
原因:在vue的生命周期中,在頁面初始化的時候mounted只會執(zhí)行一次,關(guān)閉彈窗頁面并沒有銷毀,所以不會再次執(zhí)行
<select-experience-group :trialMoneyRecordID=trialMoneyRecordID :showExperienceGroup=’showExperienceGroup’ @closeCover='handleExperienceGroup'></select-experience-group>
解決辦法:就是隱藏dialog的時候要銷毀這個dialog。給dialog加v-if,在關(guān)閉dialog的時候?qū)-if設(shè)置為false這樣會直接將其從DOM結(jié)構(gòu)中抹除,到此問題解決。
修改后代碼:
<select-experience-group :trialMoneyRecordID=trialMoneyRecordID :showExperienceGroup=’showExperienceGroup’ v-if='showExperienceGroup' //利用v-if對頁面進行銷毀@closeCover='handleExperienceGroup'></select-experience-group>
補充知識:vue element-ui Dialog對話框關(guān)閉后重新打開數(shù)據(jù)不清空
重置表單的方法
this.$refs[formRef].resetFields();
不是表單中的數(shù)據(jù),也需要重置
this.$data = this.$options.data();
以上這篇Vue中關(guān)閉彈窗組件時銷毀并隱藏操作就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. Java SiteMesh新手學(xué)習(xí)教程代碼案例2. 使用idea開發(fā)javaWeb應(yīng)用程序的思路(實現(xiàn)用戶的增刪改查)3. PHP 工程師面試的四個環(huán)節(jié)4. Spring下Filter過濾器配置全局異常處理的詳細步驟5. Android webview注入JS代碼 修改網(wǎng)頁內(nèi)容操作6. XML解析錯誤:未組織好 的解決辦法7. 解決ajax的delete、put方法接收不到參數(shù)的問題方法8. 將properties文件的配置設(shè)置為整個Web應(yīng)用的全局變量實現(xiàn)方法9. 一文秒懂idea的git插件跟翻譯插件10. axios和ajax的區(qū)別點總結(jié)
