vue學習指南:第三篇(詳細) - vue的生命周期

来源:https://www.cnblogs.com/jinfeixiang/archive/2019/08/21/11391299.html
-Advertisement-
Play Games

今天小編給大家詳細講解一下 vue 的生命周期。希望大家多多指教,哪裡有遺漏的地方,也請大家指點出來 謝謝。 一、 怎麼理解 Vue 的生命周期的? 生命周期:從無到有,到到無的一個過程。Vue的生命周期對組件來說的 或 實例來說。 簡單理解:比如我們都知道 js 中的定時器,定時器都有開始的那一秒 ...


今天小編給大家詳細講解一下 vue 的生命周期。希望大家多多指教,哪裡有遺漏的地方,也請大家指點出來 謝謝。

一、 怎麼理解 Vue 的生命周期的?

  生命周期:從無到有,到到無的一個過程。Vue的生命周期對組件來說的 或 實例來說。

簡單理解:比如我們都知道 js 中的定時器,定時器都有開始的那一秒,已經執行過程中,最後執行完畢,我們的 Vue 的生命周期就好像 定時器一樣,有許多過程,他們就像鉤子一樣,相互牽連著。

1. 在Vue當中  組件(自定義的一些標簽) 瀏覽器是無法解析的。

2.  那組件的自定義標簽怎麼使用的呢?

主要分一下幾個過程:

從創建它 》到使用它》到使用完畢》在銷毀它

3. vue實例對象是最大的組件(也可以稱它為根組件)

什麼是鉤子函數?

因為 Vue 的生命周期都是分 一個階段一個階段的 並且都是相連的。

二、Vue的生命周期 主要分 四個階段  和  八個過程

我們先說 哪四個階段:

  Create           創建

  Mount           掛載(載入)

  Update          更新

  Destroy         銷毀

又是哪八個過程呢:

  Create之前和Create之後

  Mount之前和Mount之後

  Update之前和Update之後

  Destroy之前和Destroy之後

debugger      斷點調試 在工作當中會經常用得到的

Vue的生命周期都寫在 Vue實例下

1. 第一個過程   beforeCreate 

beforeCreate 實例初始化之前。數據沒有載入(data),頁面更沒顯示。

第一步初始化之前數據(data)還沒有拿到呢,data還沒有存在就會執行它。

// 這是個函數,初始化之前
beforeCreate(){
	console.log(this.a)  // 會列印 undefined 為什麼是undefined?說明我在執行這個函數,沒數據
	debugger
}

數據還沒有載入過來,往往在這個階段做 loading 請求數據 請求狀態,因為什麼都沒有

 

2. 第二個過程 created

1.  Created 實例初始化之後。它僅僅只請求到了數據,事件,屬性等。但是沒有載入,頁面依然沒有顯示。

在這個階段 往往發送數據(ajax)請求,http請求

created(){
	console.log(this.a)//能請求到數據,但頁面不顯示
	debugger
}

2.  在created之後這個 $el 屬性還是不可見的,它會在created和beforeMount判斷一下有沒有$el這個選項。

3. Create到beforeMount 有個判斷:

1. Create到beforeMount主要是找模板,模板都是虛擬的

2.  Create -之間的過程> beforeMount之間 vue會在options 中查找有沒有 el 選項,有就把他作為模板,沒有通過 vm.$mount() 這個方法去掛載。

說白了你指定模板可以通過 el:”#app”指定,也可以通過vm.$mount()去指定

}).$mount("#app")  el:"#app",

3.  有el就繼續判斷,你有沒有template屬性,如果還要模板選項(屬性),那就直接把模板渲染出去,沒有就把el的東西渲染出去扔掉#app body裡面。

4.  如果有模板就渲染模板的東西可以看的完全沒有el了

5. Created之後數據請求過來了,就是找對應的模板

 

 

 

 

 3. 第三個過程  beforeMount

beforeMount  vue會將 el對應的模板加到 vm.$el 中去,但是還沒有掛載出去,頁面還沒有顯示。

 

 

 

現在有個問題?視圖沒渲染為啥頁面會有{{a}},button?

  首先視圖沒有出來不是說頁面沒有出來,瀏覽器在載入頁面是從上到下,從上到下載入過程中,是先執行body,還是script?先執行body,body該解析的解析,像html標簽能識別(有解析標簽的功能),而{{a}},它給當作內容渲染了,load不識別,不識別就不管了,然後你在創建實例的時候,又把裡面的東西當作模板重新再次渲染。

什麼是視圖:

  是模板裡面的東西,現在還沒有載入就不是模板。什麼時候是模板?created或beforeMount

 

在beforeMount的時候我們可以找到模板了,只是還沒有載入

 

beforeMount(){
	console.log(this.$el)
	debugger;
},

4.  第四個過程  mounted

mounted 頁面載入出來了,所有的節點都出來了

mounted(){
	console.log(this.$el)
	debugger;
},

5.   第五個過程  beforeUpdated   更新也分兩個  更新前 和 更新後

beforeUpdated 數據更新前

beforeUpdate(){
	console.log("數據準備更新")
	debugger;
},

 

 

在虛擬 dom 中使用 differ演算法,在記憶體中實現,Mounted之前過程就不管了,更新就載入,載入過程中不是全部都載入,如果是全部載入又要回到出發點,哪裡更新了我在虛擬dom進行對比下,對比完重新在去掛載,誰變了誰去掛載,誰去更新,之前的整個dom樹不會跟著你一起更新,如果跟著你更新又會回到起點(beforeCreate),muntud之前都不管了。如果想看屬性的變化可以使用 watch(屬性監聽)這個方法。

  

6. 第六個過程  Updated  

Updated 更新完

更新完,在渲染,誰改變了渲染誰。不是整個dom樹重新渲染

 

7.  第七個過程  銷毀也分兩個,銷毀前和銷毀後

銷毀前 before Destory

銷毀後 destroy

實例銷毀需要人為觸發

註意:這個地方問題很多尤其是組件拼接,組件裡面套組件的時候

銷毀:之前渲染好的保持不變 保留下來,後面再使用這個實例就不起作用了。

怎麼銷毀?

通過 vm.$destory()

 

三、組件的生命周期:

實例裡面套組件

組件也有生命周期

嵌套組件生命周期的執行順序:

  先執行實例的vm.beforecreate -> 依然是vm.created -> 下一個還是vm.beforeMount ->這一塊主要找el模板 模板里有組件,有組件開始走子組件裡面的了是son.beforecreate。後期調數據的時候哪裡該調哪裡不該調,跟順序有很大關係,如果調錯了數據不會被更改的。

 

先執行實例的vm.beforecreate -> vm.created ->vm.beforeMount -> son.beforecreate -> son.created ->son.beforeMount ->繼續執行 son.mountnd -> vm.mounted(又回到父級身上)

 

註意:正常載入是這樣的:

先執行實例的vm.beforecreate -> vm.created ->vm.beforeMount ->先執行到父組件的beforeMount準備載入,再去找模板,發現模板裡面有子組件然後對子組件進行渲染。son.beforecreate -> son.created ->son.beforeMount ->繼續執行 son.mountnd ->,載入完之後再去載入父組件。

以上三個順序是一樣的,我給細節化,方便大家理解

註意:

1.  組件嵌套的時候數據怎麼改都改不了,說明根生命周期順序有關。

2.  請求的數據在子組件是a,但是在父組件還是原來的,所以給生命周期順序有關。

 

更改組件類的數據 修改子組件的數據順序:

先執行實例的vm.beforecreate -> vm.created ->vm.beforeMount -> son.beforecreate -> son.created ->son.beforeMount ->繼續執行 son.mountnd -> vm.mounted(又回到父級身上) -> son.beforeUpdate -> son.updated

 

組件更新數據,只會調用自己的 beforeupdate和updated ,不會影響到其它組件的更新鉤子。如果說父組件獲取子組件中的標簽中的內容(這個內容會被子組件修改),父組件獲取的都是修改前的內容,因為子組件的更新,不會再去觸發父組件的 mounted,this. $nexTick() 它是組件中(包括子組件)所有的鉤子執行完畢之後才會觸發。

 

 作者:晉飛翔

手機號(微信同步):17812718961

 如果覺得小編 寫的還可以,請給小編一個鼓勵的贊吧,謝謝各位朋友

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本數據源來自 https://www.kafan.cn/edu/922556.html 目的為了備忘 把原來的sql server 2005直接裝成了2012,然後在建立鏈接伺服器鏈接一臺sql server 2000的伺服器時,報錯信息大概是“SQL Server Native Client 11 ...
  • 如果你還不知道redis的基本命令與基本使用方法,請看 【redis】redis基礎命令學習集合 緩存 redis還有另外一個重要的應用領域——緩存 引用來自網友的圖解釋緩存在架構中的位置 預設情況下,我們的服務架構如下圖,客戶端請求service,然後service去讀取mysql資料庫 問題存在 ...
  • kafka0.9版本以後用java重新編寫了producer,廢除了原來scala編寫的版本。 這裡直接使用最新2.3版本,0.9以後的版本都適用。 註意引用的包為:org.apache.kafka.clients.producer 0.11.0以後增加了事務,事務producer的示例代碼如下,需 ...
  • 前言 本文主要介紹的是ElasticSearch集群和kinaba的安裝教程。 ElasticSearch介紹 ElasticSearch是一個基於Lucene的搜索伺服器,其實就是對Lucene進行封裝,提供了 REST API 的操作介面. ElasticSearch作為一個高度可拓展的開源全文 ...
  • 今天來學習下TextField文本框組件和Card卡片組件。 只要是應用程式就少不了交互,基本上所有的應用程式都會有用戶名、密碼輸入框,搜索框等等,前面我們有寫過一篇基於Form表單的輸入功能,今天來看一下TextField文本框組件,文本輸入是最常見的一種交互方式,TextField組件就是... ...
  • 試過網上很多的例子,有的設置Go to `File->Settings->Build, Execution, Deployment->Gradle->Uncheck Offline work option.` 但我的沒成功,後來發現 打開C:/Users/(用戶名)/.gradle/gradle.p ...
  • 主要是javaScript的基礎 變數 數據類型 運算符 表達式 怎樣定義 ...
  • 問題 今天組長跟我們討論了個問題,說是文章存儲占用有點大,消耗寬頻流量費,讓我看看能不能找個方法解決一下(文章存儲的是html字元串)。第一反應是沒什麼頭緒,能想到的就是將相同的字元串替換成一個標識之類的,小程式再通過標識替換回原本的字元(感覺就不是很靠譜...)。 後來發現真的不靠譜,首先每篇文章 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...