Vue 中生命周期定義及流程
一、生命周期定義
生命周期:又名:生命周期回調函數、生命周期函數、生命周期鉤子
生命周期是什麼:Vue在關鍵時刻幫我們調用的一些特殊名稱的函數 3.生命周期函數的名字不可更改,但函數的具體內容是程序員根據需求編寫的 4.生命周期函數中的 this 指向是 vm 或組件實例對象
做一個小例子,要求頁面的文字一上來透明度就周而復始的從1變到0
<div id="root"> <h2 :style="{opacity: opacity}">好好學習</h2> <h2 :style="{opacity}">天天向上</h2> </div>
<script type="text/javascript"> Vue.config.productionTip = false //創建vue實例 new Vue({ el: "#root", data: { opacity: 1 },//Vue完成模板解析,並把初始的真實dom放入頁面後(掛載完畢)調用mounted mounted(){ setInterval(()=>{ this.opacity -= 0.01 if(this.opacity <=0) this.opacity = 1 },20) } }) </script>
二、生命周期流程
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Vue初識</title> <script type="text/javascript" src="./js/vue.js"></script> </head> <body> <div id="root"> <h2 :style="{opacity}">天天向上</h2> <button @click="opacity = 1">透明度設置為1</button> <button @click="stop">點我停止變換</button> </div> <script type="text/javascript"> Vue.config.productionTip = false //創建vue實例 new Vue({ el: "#root", data: { opacity: 1 }, methods:{ stop(){ this.$destroy() } }, mounted(){ this.timer = setInterval(()=>{ this.opacity -= 0.01 if(this.opacity <=0) this.opacity = 1 },20) }, beforeDestroy(){ console.log("beforeDestroy") clearInterval(this.timer) } }) </script> </body> </html>
三、總結
vm的一生(vm的生命周期):
- 將要創建——>調用
beforeCreate
函數 - 創建完畢——>調用
created
豳數 - 將要掛載——>調用
beforeMount
函數 - 掛載完畢——>調用
mounted
函數【重要的鉤子】 - 將要更新——>調用
beforeUpdate
函數 - 更新完畢——>調用
updated
函數。 - 將要銷毀——>調用
beforeDestroy
函數【重要的鉤子】 - 銷毀完畢——>調用
destroyed
函數
常用的生命周期鉤子:
- 1.
mounted
:發送ajax請求、啟動定時器、綁定自定義事件、訂閱消息等【初始化操作】 - 2.
beforeDestroy
:清除定時器、解綁自定義事件、取消訂閱消息等【收尾工作】
關於銷毀Vue實例:
- 1、銷毀後借助Vue開發者工具看不到任何信息
- 2、銷毀後自定義事件會失效,但原生DOM事件依然有效
- 3、一般不會在
beforeDestroy
操作數據,因為即便操作數據,也不會再觸發更新流程瞭
到此這篇關於Vue 中生命周期定義及流程的文章就介紹到這瞭,更多相關Vue 生命周期內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!