日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > vue >内容正文

vue

初探 Vue 生命周期和钩子函数

發布時間:2025/4/5 vue 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 初探 Vue 生命周期和钩子函数 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

生命周期

生命周期函數就是 Vue 實例在某一個時間點會自動執行的函數。

簡單來說就是好像把人的出生到死亡分成一個個階段,你取名字肯定是在你出生階段,而不是在成年階段;你結婚肯定是在成年階段,而不是在出生階段;如果說你在出生階段想去階段,那肯定是不行的。
組件也是一樣,在實例化的時特定階段調用特定方法,調用的這個方法就是鉤子函數。

鉤子函數

鉤子函數和回調函數有什么區別嗎?

它們區別是:

js派函數監聽事件 => 監聽函數就是所謂的鉤子函數 => 函數鉤取事件:函數主動找事件 => 鉤子函數

js預留函數給dom事件,dom事件調用js預留的函數 => 事件派發給函數:事件調用函數 => 回調函數

打個比方:

鉤子函數:一個房間里的監控攝像頭監控著每一個進入的人的面部特征,識別出了符合條件的人就觸發警告(執行函數事件);

回調函數:可以看做是在一片地區埋了許許多多的地雷,一旦踩中了某個地雷(觸發事件),地雷就會爆炸(執行函數事件)。

可以簡單的理解為:

鉤子函數是事件被動的監聽,一旦條件觸發就執行

回調函數是主動事件,執行函數體內容

生命周期探究

<template><div>{{msg}}</div> </template><script> export default {name: 'HelloWorld',data () {return {msg: 'hello world',msg1: ''}},beforeCreate () {console.groupCollapsed('beforeCreate 創建前狀態')console.log('%c%s', 'color:MediumVioletRed', 'el : ' + this.$el)console.log(this.$el)console.log('%c%s', 'color:MediumVioletRed', 'data : ' + this.$data)console.log(this.$data)console.log('%c%s', 'color:MediumVioletRed', 'msg: ' + this.msg)console.groupEnd()},created () {console.groupCollapsed('created 創建前狀態')console.log('%c%s', 'color:MediumVioletRed', 'el : ' + this.$el)console.log(this.$el)console.log('%c%s', 'color:MediumVioletRed', 'data : ' + this.$data)console.log(this.$data.msg)console.log('%c%s', 'color:MediumVioletRed', 'msg: ' + this.msg)console.groupEnd()},beforeMount () {console.groupCollapsed('beforeMount 掛載前狀態')console.log('%c%s', 'color:MediumVioletRed', 'el : ' + this.$el)console.log(this.$el)console.log('%c%s', 'color:MediumVioletRed', 'data : ' + this.$data)console.log(this.$data.msg)console.log('%c%s', 'color:MediumVioletRed', 'msg: ' + this.msg)console.groupEnd()},mounted () {console.groupCollapsed('mounted 掛載后狀態')console.log('%c%s', 'color:MediumVioletRed', 'el : ' + this.$el)console.log(this.$el)console.log('%c%s', 'color:MediumVioletRed', 'data : ' + this.$data)console.log(this.$data.msg)console.log('%c%s', 'color:MediumVioletRed', 'msg: ' + this.msg)console.groupEnd()setTimeout(() => {this.$data.msg = '123'}, 5000)},activated () {console.groupCollapsed('activated 掛載后狀態')console.log('%c%s', 'color:MediumVioletRed', 'el : ' + this.$el)console.log(this.$el)console.log('%c%s', 'color:MediumVioletRed', 'data : ' + this.$data)console.log(this.$data.msg)console.log('%c%s', 'color:MediumVioletRed', 'msg: ' + this.msg)console.groupEnd()setTimeout(() => {this.$data.msg = 'hello tiantian'}, 10000)},beforeUpdate () {console.groupCollapsed('beforeUpdate 更新前狀態')console.log('%c%s', 'color:MediumVioletRed', 'el : ' + this.$el)console.log(this.$el)console.log('%c%s', 'color:MediumVioletRed', 'data : ' + this.$data)console.log(document.getElementById('app').innerHTML)console.log('%c%s', 'color:MediumVioletRed', 'msg: ' + this.msg)console.groupEnd()},updated () {console.groupCollapsed('updated 更新后狀態')console.log('%c%s', 'color:MediumVioletRed', 'el : ' + this.$el)console.log(this.$el)console.log('%c%s', 'color:MediumVioletRed', 'data : ' + this.$data)console.log(document.getElementById('app').innerHTML)console.log('%c%s', 'color:MediumVioletRed', 'msg: ' + this.msg)console.groupEnd()setTimeout(() => {this.$destroy()}, 5000)},beforeDestroy () {console.groupCollapsed('beforeDestroy 實例銷毀前狀態')console.log('%c%s', 'color:MediumVioletRed', 'el : ' + this.$el)console.log(this.$el)console.log('%c%s', 'color:MediumVioletRed', 'data : ' + this.$data)console.log(document.getElementById('app').innerHTML)console.log('%c%s', 'color:MediumVioletRed', 'msg: ' + this.msg)console.groupEnd()},destroyed () {console.groupCollapsed('destroyed 實例銷毀后狀態')console.log('%c%s', 'color:MediumVioletRed', 'el : ' + this.$el)console.log(this.$el)console.log('%c%s', 'color:MediumVioletRed', 'data : ' + this.$data)console.log(document.getElementById('app').innerHTML)console.log('%c%s', 'color:MediumVioletRed', 'msg: ' + this.msg)console.groupEnd()} } </script>

beforeCreate和created

beforeCreate:在實例初始化完成時,被執行

created:在初始化結束之后會再初始化一些外部注入和一些雙向綁定相關的事情時,被執行

這兩個鉤子函數執行完之后,初始化基本完成了。

在beforeCreate階段,el和data都沒有被掛載;而在created階段,el還沒被掛在,但data已經被掛載了,如下圖所示:

這里el為啥沒有被掛載呢?

看上圖,在created執行完畢后,它會詢問一個條件:你這個Vue實例里是否有el這個選項。

如果有就又會詢問是否有template這個選項:

  • 如果沒有template就會走右側的分支,

    • 如果這個實例沒有template,就會將el這個根節點當做模版,來進行渲染
  • 如果有template就會走左側的分支

    • 把template作為模版去渲染

beforeMount和mounted

beforeMount:執行時,頁面還沒有被渲染
mounted:執行時,頁面已經被渲染了

從圖中也可以看出,在beforeMount執行時,el還沒有被掛在;當mounted執行時,el被掛載到頁面了。

beforeUpdate和updated

beforeUpdate:數據被改變,還沒渲染之前會被執行

updated:數據被改變,渲染完成后會被執行

這張圖中有個奇怪的現象,為什么在beforeUpdate和updated兩個鉤子函數中,el和msg都是一樣呢?beforeUpdate執行是不應該是老數據嘛,怎么這里也是最新的數據了?

因為這里的el是虛擬dom,不是真實的dom,和data都是對象,在加上console.log這里是個異步操作,當你點開console.log時,其實代碼早就跑完了,數據已經是最新的了,所以就會看到在這兩個函數中輸出結果是一樣的了。

可以用document.getElementById('app').innerHTML獲取真實的Dom結構,這時我們就可以看到這兩處不一樣的地方了。

beforeDestroy和destroyed

調用vm.$destroy()方法可對實例銷毀

beforeDestroy:實例被銷毀前被執行

destroyed:實例被銷毀后被執行

activated和deactivated

使用keep-alive標簽后,會有兩個生命周期函數分別是:activated、deactivated

activated:頁面展示的時候被執行

deactivated:頁面被隱藏或者頁面即將被替換成新的頁面時被執行

總結

created:掛載之前需要做的一些事情可以在放在這里面,比如頁面加載時loading動畫

mounted:向后端發請求,可以放在這個函數中。

這兩個鉤子函數使用時機重疊部分很多,反正是怎么方便怎么來就是了。

參考資源

  • Vue2.0 探索之路——生命周期和鉤子函數的一些理解
  • vue2 為什么beforeUpdate時的$el 和$data與updated時的一樣
  • JavaScript:鉤子函數與回調函數的區別
  • 《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀

    總結

    以上是生活随笔為你收集整理的初探 Vue 生命周期和钩子函数的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: 99久久婷婷国产综合精品青牛牛 | 中国女人内谢69xxxx免费视频 | 免费无码国产v片在线观看 三级全黄做爰在线观看 | 久久精品夜 | 欧美波霸影院 | 日韩av网站在线 | 亚洲福利视频一区 | 国产精品99 | 超碰97国产精品人人cao | 国产调教在线 | 伊人蕉久影院 | 久草新免费 | 久久精品国产亚洲av嫖农村妇女 | 亚洲天堂欧美在线 | 久久奇米| 日本三级一区二区 | 日韩精品一区中文字幕 | 天天综合网永久 | 成人国产欧美 | 在线观看一区二区视频 | 中文字幕一区二区三区精彩视频 | 久久久久久久久久久久久久久 | 精品人妻av一区二区 | 3d动漫精品啪啪一区二区免费 | 中文字幕一区二区三区四区 | 福利在线影院 | 蜜桃va| 国产人伦精品一区二区三区 | 久久久久国产精品 | 亚洲区视频 | 欧美丰满老熟妇aaaa片 | a级全黄 | 亚洲精品视频在线观看视频 | 成年人www | 免费在线观看亚洲 | 亚洲色图久久 | 99精品在线观看 | 精品欧美激情精品一区 | 嫩草视频在线播放 | 久久中文av| 亚洲一区二区三区激情 | 国产污污 | 天堂在线一区二区 | 久久免费视频一区二区 | 爱插视频 | 国产精品久久久久久久久免费相片 | 色婷婷av一区二区三区之红樱桃 | 久久久久麻豆 | 老司机深夜福利网站 | 青青综合网 | 九九久久综合 | 精品美女一区二区三区 | 亚洲综合免费观看高清完整版 | 日韩欧美亚洲一区二区三区 | 美女精品一区二区 | 99热一区二区三区 | 九九九九精品 | 欧美一区2区三区4区公司 | 男人和女人做爽爽视频 | 国产日韩欧美在线观看 | 91网页入口 | 久久精品国产亚洲av蜜臀色欲 | 日本人妻不卡一区二区三区中文字幕 | 国产va在线| 麻豆乱码国产一区二区三区 | 天天干免费视频 | 国产午夜福利一区 | 懂色av懂色av粉嫩av分享吧 | 色呦呦精品 | 在线精品视频播放 | 成人国产精品蜜柚视频 | 黄色日皮视频 | 97在线免费 | 深夜视频一区二区 | 日韩av在线第一页 | 国产精品久久久久久久专区 | 国产一区二区三区乱码 | 亚洲精品乱码久久久久久蜜桃不卡 | 美女喷液视频 | 亚洲一级av无码毛片精品 | 中国一级片黄色一级片黄 | 91在线观看欧美日韩 | 精品aaa| 久久久久久久久久久电影 | 一级片视频免费看 | 久精品在线观看 | 成年人三级视频 | 插插宗合网 | 美女脱光衣服让男人捅 | 亚洲成av人在线观看 | 国产精品18久久久久久无码 | 手机av网站| 99国产在线播放 | a极黄色片 | 日韩亚射吧| 国产www性| 欧美激情黑白配 | 超碰人人人 | 欧美18免费视频 |