javascript - 請問一下組件的生命周期beforeDestory是在什么情況下面觸發的呢?
問題描述
進行路由跳轉的時候能觸發嗎?我發現我進行路由跳轉的時候沒有觸發beforeDestory里面的函數,但是有段代碼需要在組件銷毀之前執行,請問我應該怎么做呢?https://jsfiddle.net/44w37p34/ 剛剛有個朋友給我發了一個demo,我發現他的beforeDestory在路由跳轉的時候觸發了,但是我的一直都不行,請問是什么原因呢
問題解答
回答1:找到原因了,之前給router-view加了個keep-alive導致組件緩存了,所以不會觸發beforeDestory和destoryed
回答2:我試了一下,切換路由的時候能觸發執行beforeDestroy方法,示例如下。
const Home = {template: ` <p> <p class='section'>Some section foo</p> <p class='section'>Some section foo</p> <p class='section'>Some section foo</p> <p class='section'>Some section foo</p> </p> `,mounted() { console.log('Home mounted');},beforeDestroy() { console.log('Home destroy');} }; const Test = {template: ` <p> <p class='section'>Some section test</p> <p class='section'>Some section test</p> <p class='section'>Some section test</p> <p class='section'>Some section test</p> </p> `,mounted() { console.log('Test mounted');},beforeDestroy() { console.log('Test destroy');} };
相關文章:
1. 這段代碼是獲取百度收錄量的!需要怎么設置才能獲取百度快照旁邊的網址呢?2. vue.js - vue 打包后 nginx 服務端API請求跨域問題無法解決。3. angular.js - angular指令中的scope屬性中用&獲取父作用域函數的問題4. CSS響應式導航原理,下圖那個具體怎么做出來的?5. html5 - node.js下載失敗,求大神解釋6. html5 - canvas 跨域問題7. oracle - mysql如何將group by的行數據轉為列8. javascript - 切換掉當前頁面后該頁面的js動畫會暫停?9. mysql - 大部分數據沒有行溢出的text字段是否需要拆表10. javascript - svg小白,想要在svg里面插入圖片
