欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue中created和mounted使用場(chǎng)景分析

 更新時(shí)間:2023年05月13日 14:42:28   作者:慕白Lee  
vue.js中created方法是一個(gè)生命周期鉤子函數(shù),一般可以在created函數(shù)中調(diào)用ajax獲取頁面初始化所需的數(shù)據(jù),這篇文章主要介紹了Vue中created和mounted使用場(chǎng)景分析,需要的朋友可以參考下

一、生命周期概念

通俗地講,生命周期即Vue實(shí)例或組件從創(chuàng)建到被消滅的一系列過程,中間的各個(gè)節(jié)點(diǎn)被稱為鉤子.vue.js中created方法是一個(gè)生命周期鉤子函數(shù),一個(gè)vue實(shí)例被生成后會(huì)調(diào)用這個(gè)函數(shù)。一個(gè)vue實(shí)例被生成后還要綁定到某個(gè)html元素上,之后還要進(jìn)行編譯,然后再插入到document中。每一個(gè)階段都會(huì)有一個(gè)鉤子函數(shù),方便開發(fā)者在不同階段處理不同邏輯。一般可以在created函數(shù)中調(diào)用ajax獲取頁面初始化所需的數(shù)據(jù)。

二、瀏覽器渲染過程

要深刻理解生命周期的各個(gè)節(jié)點(diǎn),就必須了解瀏覽器的渲染過程

  • 構(gòu)建DOM樹
  • 構(gòu)建css規(guī)則樹,根據(jù)執(zhí)行順序解析js文件。
  • 構(gòu)建渲染樹Render Tree
  • 渲染樹布局layout
  • 渲染樹繪制

三、生命周期中的瀏覽器渲染

  • created:已創(chuàng)建,在模板渲染成html前調(diào)用,即通常初始化某些屬性值,然后再渲染成視圖。
  • mounted:已掛載,在模板渲染成html后調(diào)用,通常是初始化頁面完成后,再對(duì)htmldom節(jié)點(diǎn)進(jìn)行一些操作。

通常created使用的次數(shù)多,而mounted是在一些插件或組件的使用中進(jìn)行操作,
比如插件chart.js的使用: var ctx = document.getElementById(ID);
通常會(huì)有這一步,而如果你寫入組件中,
你會(huì)發(fā)現(xiàn)在created中無法對(duì)chart進(jìn)行一些初始化配置,
一定要等這個(gè)html渲染完后才可以進(jìn)行,那么mounted就是不二之選。

生命周期是否獲取dom節(jié)點(diǎn)是否獲取data是否獲取methods
beforeCreate
created
beforeMount
mounted

beforeCreate階段

對(duì)瀏覽器來說,整個(gè)渲染流程尚未開始或者說準(zhǔn)備開始,對(duì)vue來說,實(shí)例尚未被初始化,data observer和 event/watcher也還未被調(diào)用,在此階段,對(duì)data、methods或文檔節(jié)點(diǎn)的調(diào)用現(xiàn)在無法得到正確的數(shù)據(jù)。

created階段

對(duì)瀏覽器來說,渲染整個(gè)HTML文檔時(shí),dom節(jié)點(diǎn)、css規(guī)則樹與js文件被解析后,但是沒有進(jìn)入被瀏覽器render過程,上述資源是尚未掛載在頁面上,也就是在vue生命周期中對(duì)應(yīng)的created階段,實(shí)例已經(jīng)被初始化,但是還沒有掛載至 $el上,所以我們無法獲取到對(duì)應(yīng)的節(jié)點(diǎn),但是此時(shí)我們是可以獲取到vue中data與methods中的數(shù)據(jù)的

beforeMount階段

實(shí)際上與created階段類似,節(jié)點(diǎn)尚未掛載,但是依舊可以獲取到data與methods中的數(shù)據(jù)。

mounted階段

對(duì)瀏覽器來說,已經(jīng)完成了dom與css規(guī)則樹的render,并完成對(duì)render tree進(jìn)行了布局,而瀏覽器收到這一指令,調(diào)用渲染器的paint()在屏幕上顯示,而對(duì)于vue來說,在mounted階段,vue的template成功掛載在$el中,此時(shí)一個(gè)完整的頁面已經(jīng)能夠顯示在瀏覽器中,所以在這個(gè)階段,即可以調(diào)用節(jié)點(diǎn)了(關(guān)于這一點(diǎn),在筆者測(cè)試中,在mounted方法中打斷點(diǎn)然后run,依舊能夠在瀏覽器中看到整體的頁面)。

四、使用場(chǎng)景

通過瀏覽器的渲染過程,可以總結(jié)出created和mounted的使用場(chǎng)景

    created:通常用于初始化某些屬性值,例如data中的數(shù)據(jù),然后再渲染成視圖。
    mounted:通常在初始化頁面完成后,對(duì)html的dom節(jié)點(diǎn)進(jìn)行需要的操作。

因此,在created中,是無法進(jìn)行DOM操作的,而mounted可以獲取渲染出來的所有屬性值。

五、常見相關(guān)問題

一些頁面跳轉(zhuǎn)后, 一些基礎(chǔ)數(shù)據(jù)接口沒有重新請(qǐng)求

舉個(gè)簡單的例子
 created(){ 
	this.init();
  }, 
mounted() {
    this.init();
  },
 methods: {
    init() {
        this.getList();
        this.getdetailById();
        this.getFicts();
      }
    },
}

到此這篇關(guān)于Vue中created和mounted詳解的文章就介紹到這了,更多相關(guān)Vue中created和mounted內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 使用vue-cli創(chuàng)建項(xiàng)目并webpack打包的操作方法

    使用vue-cli創(chuàng)建項(xiàng)目并webpack打包的操作方法

    本文給大家分享使用vue-cli創(chuàng)建項(xiàng)目基于webpack模板打包的配置方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2021-07-07
  • vue中post請(qǐng)求報(bào)400的解決方案

    vue中post請(qǐng)求報(bào)400的解決方案

    這篇文章主要介紹了vue中post請(qǐng)求報(bào)400的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • 使用vue指令實(shí)現(xiàn)吸頂效果

    使用vue指令實(shí)現(xiàn)吸頂效果

    要想實(shí)現(xiàn)一個(gè)吸頂效果不是很難,網(wǎng)絡(luò)上有很多教程,其中有一種就是通過fiexd加top來實(shí)現(xiàn),今天突然就想做一個(gè)吸頂效果,因?yàn)樽罱荚谟胿ue,所以想用vue來做一個(gè)吸頂效果的案例,感興趣的朋友可以參考下
    2023-11-11
  • vue2.0實(shí)現(xiàn)列表數(shù)據(jù)增加和刪除

    vue2.0實(shí)現(xiàn)列表數(shù)據(jù)增加和刪除

    這篇文章主要為大家詳細(xì)介紹了vue2.0實(shí)現(xiàn)列表數(shù)據(jù)增加和刪除,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-06-06
  • Vue Element前端應(yīng)用開發(fā)之圖標(biāo)的維護(hù)和使用

    Vue Element前端應(yīng)用開發(fā)之圖標(biāo)的維護(hù)和使用

    在Vue Element前端應(yīng)用中,圖標(biāo)是必不可少點(diǎn)綴界面的元素,Element界面組件里面提供了很多常見的圖標(biāo),因此考慮擴(kuò)展更多圖標(biāo),引入了vue-awesome組件,它利用了Font Awesome的內(nèi)置圖標(biāo),實(shí)現(xiàn)了更多圖標(biāo)的整合,可以在項(xiàng)目中使用更多的圖標(biāo)元素了
    2021-05-05
  • vue實(shí)現(xiàn)兩個(gè)區(qū)域滾動(dòng)條同步滾動(dòng)

    vue實(shí)現(xiàn)兩個(gè)區(qū)域滾動(dòng)條同步滾動(dòng)

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)兩個(gè)區(qū)域滾動(dòng)條同步滾動(dòng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • apache和nginx下vue頁面刷新404的解決方案

    apache和nginx下vue頁面刷新404的解決方案

    這篇文章主要介紹了apache和nginx下vue頁面刷新404的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • vue-cli項(xiàng)目中使用Mockjs詳解

    vue-cli項(xiàng)目中使用Mockjs詳解

    這篇文章主要介紹了vue-cli項(xiàng)目中使用Mockjs詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-05-05
  • Vue左滑組件slider使用詳解

    Vue左滑組件slider使用詳解

    這篇文章主要為大家詳細(xì)介紹了Vue左滑組件slider的使用,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-08-08
  • Vue中JSX的基本用法及高級(jí)部分

    Vue中JSX的基本用法及高級(jí)部分

    JSX是一種Javascript的語法擴(kuò)展,JSX = Javascript + XML,即在 Javascript里面寫XML,因?yàn)?nbsp;JSX 的這個(gè)特性,所以他即具備了 Javascript的靈活性,同時(shí)又兼具h(yuǎn)tml的語義化和直觀性,這篇文章主要給大家介紹了關(guān)于Vue中JSX的基本用法及高級(jí)部分的相關(guān)資料,需要的朋友可以參考下
    2022-11-11

最新評(píng)論