關(guān)于Android工程師轉(zhuǎn)vue的三兩事兒(6)--生命周期

關(guān)于生命周期其實(shí)在Android是一個(gè)比較常見的話題,我在接觸前端的時(shí)候难菌,我首先研究的就是這個(gè)東西燎潮。因?yàn)槟阒挥邪盐兆∵@個(gè)東西生命線,你才能更好的去運(yùn)用它憨闰,我這里就結(jié)合我自己的一些所見所聞做一點(diǎn)生命周期的介紹状蜗。

一、 生命周期示意圖:

vue生命周期示意圖

如上圖所示鹉动,在vue組件生命周期內(nèi)一共經(jīng)歷:

  • beforeCreate:組件創(chuàng)建前
  • created:組件創(chuàng)建
  • beforeMount:組件掛載前
  • mounted:組件掛載
  • beforeUpdate:組件更新前
  • updated:組件更新
  • beforeDestroy:組件銷毀前
  • destroyed:組件銷毀
    上面分別是對(duì)于組件生命周期的一些概述轧坎,但是并沒有去結(jié)合代碼去看,感覺帶入感并沒有這么強(qiáng)泽示,下面就用代碼引入的方法詳細(xì)的向大家介紹

二缸血、代碼解讀

<template>
  <div ref="myapp" id="app">
    <img src="./assets/logo.png">
    <div>{{message}}</div>
    <button @click="tokenMsg">說點(diǎn)什么</button>
  </div>
</template>

<script>
  export default {
    data(){
      return{
        message: '我是一個(gè)菜鳥'
      }
    },
    methods: {
      tokenMsg(){
        this.message += "+1";
      }
    },
    beforeCreate() {
      console.group('beforeCreate 創(chuàng)建前狀態(tài)===============》');
      console.log("%c%s", "color:red" , "el     : " + this.$refs.myapp);
      console.log("%c%s", "color:red","data   : " + this.$data);
      console.log("%c%s", "color:red","message: " + this.message)
    },
    created: function () {
      console.group('created 創(chuàng)建完畢狀態(tài)===============》');
      console.log("%c%s", "color:red","el     : " + this.$refs.myapp);
      console.log("%c%s", "color:red","data   : " + this.$data);
      console.log("%c%s", "color:red","message: " + this.message);
    },
    beforeMount: function () {
      console.group('beforeMount 掛載前狀態(tài)===============》');
      console.log("%c%s", "color:red","el     : " + (this.$refs.myapp));
      console.log(this.$refs.myapp);
      console.log("%c%s", "color:red","data   : " + this.$data);
      console.log("%c%s", "color:red","message: " + this.message);
    },
    mounted: function () {
      console.group('mounted 掛載結(jié)束狀態(tài)===============》');
      console.log("%c%s", "color:red","el     : " + this.$refs.myapp);
      console.log(this.$refs.myapp);
      console.log("%c%s", "color:red","data   : " + this.$data);
      console.log("%c%s", "color:red","message: " + this.message);
    },
    beforeUpdate: function () {
      console.group('beforeUpdate 更新前狀態(tài)===============》');
      console.log("%c%s", "color:red","el     : " + this.$refs.myapp);
      console.log(this.$refs.myapp);
      console.log("%c%s", "color:red","data   : " + this.$data);
      console.log("%c%s", "color:red","message: " + this.message);
    },
    updated: function () {
      console.group('updated 更新完成狀態(tài)===============》');
      console.log("%c%s", "color:red","el     : " + this.$refs.myapp);
      console.log(this.$refs.myapp);
      console.log("%c%s", "color:red","data   : " + this.$data);
      console.log("%c%s", "color:red","message: " + this.message);
    },
    beforeDestroy: function () {
      console.group('beforeDestroy 銷毀前狀態(tài)===============》');
      console.log("%c%s", "color:red","el     : " + this.$refs.myapp);
      console.log(this.$refs.myapp);
      console.log("%c%s", "color:red","data   : " + this.$data);
      console.log("%c%s", "color:red","message: " + this.message);
    },
    destroyed: function () {
      console.group('destroyed 銷毀完成狀態(tài)===============》');
      console.log("%c%s", "color:red","el     : " + this.$refs.myapp);
      console.log(this.$refs.myapp);
      console.log("%c%s", "color:red","data   : " + this.$data);
      console.log("%c%s", "color:red","message: " + this.message)
    }
  }
</script>

上面的項(xiàng)目就是我用vue-cli腳手架新建的一個(gè)vue項(xiàng)目。并且改代碼只要拷貝進(jìn)項(xiàng)目可以直接去查看械筛。運(yùn)行效果如下

Chrome調(diào)試器log

從上面的log上面其實(shí)可以看出來:
1捎泻、 beforecreate data和組件都沒有被初始化的狀態(tài)
2、create data里面的內(nèi)容已經(jīng)可以訪問到了
3埋哟、 mounted 頁面已經(jīng)被掛載成功了笆豁。
那么結(jié)合代碼,當(dāng)點(diǎn)擊button的時(shí)候赤赊,發(fā)現(xiàn)console會(huì)發(fā)生變化
更新data里面的數(shù)據(jù)

由上圖可知闯狱,當(dāng)頁面data內(nèi)的數(shù)據(jù)發(fā)生變化的時(shí)候,并不會(huì)觸發(fā)上面說到的生命周期方法抛计,而是會(huì)觸發(fā)到beforeupdate和update方法哄孤。
image.png

同理當(dāng)頁面關(guān)閉的時(shí)候,頁面會(huì)先beforedestroy和destroyed方法爷辱。其中可以看見的是:
1录豺、beforedestroy狀態(tài)下,所有的頁面內(nèi)都是可以訪問的狀態(tài)
2饭弓、destroyed下,組件會(huì)被回收媒抠,但是data卻依舊能被訪問

三弟断、 生命周期總結(jié)

生命周期總結(jié)圖

可能這里結(jié)合實(shí)踐我可能需要bb兩句:
一、 created階段的ajax請(qǐng)求與mounted請(qǐng)求的區(qū)別:前者頁面視圖未出現(xiàn)趴生,如果請(qǐng)求信息過多阀趴,頁面會(huì)長時(shí)間處于白屏狀態(tài)
二昏翰、 mounted 不會(huì)承諾所有的子組件也都一起被掛載。如果你希望等到整個(gè)視圖都渲染完畢刘急,可以用 vm.$nextTick

四棚菊、 父子組件生命周期

父組件如下:

<template>
  <div ref="myapp" id="app">
    <child-view v-if="showView"/>
    <div>{{message}}</div>
    <button @click="tokenMsg">說點(diǎn)什么</button>
    <button @click="displayView">銷毀子組件</button>
  </div>
</template>

<script>
  import ChildView from './components/HelloWorld'
  export default {
    components:{
      ChildView
    },
    data(){
      return{
        message: '我是一個(gè)菜鳥',
        showView: true
      }
    },
    methods: {
      tokenMsg(){
        this.message += "+1";
      },
      displayView(){
        this.showView = !this.showView;
      }
    },
    beforeCreate() {
      console.group('beforeCreate 創(chuàng)建前狀態(tài)===============》');
    },
    created: function () {
      console.group('created 創(chuàng)建完畢狀態(tài)===============》');
    },
    beforeMount: function () {
      console.group('beforeMount 掛載前狀態(tài)===============》');
    },
    mounted: function () {
      console.group('mounted 掛載結(jié)束狀態(tài)===============》');
    },
    beforeUpdate: function () {
      console.group('beforeUpdate 更新前狀態(tài)===============》');
    },
    updated: function () {
      console.group('updated 更新完成狀態(tài)===============》');
    },
    beforeDestroy: function () {
      console.group('beforeDestroy 銷毀前狀態(tài)===============》');
    },
    destroyed: function () {
      console.group('destroyed 銷毀完成狀態(tài)===============》');
    }
  }
</script>

子組件如下:

<template>
  <div style="background: red;color: #ffffff;">
    {{msg}}
    <button @click="addMsg">說點(diǎn)什么</button>
  </div>
</template>

<script>
  export default {
    methods: {
      addMsg(){
        this.msg += "+2"
      }
    },
    beforeCreate() {
      console.log('child beforeCreate 創(chuàng)建前狀態(tài)===============》')
    },
    created: function () {
      console.log('child created 創(chuàng)建完畢狀態(tài)===============》');
    },
    beforeMount: function () {
      console.log('child beforeMount 掛載前狀態(tài)===============》');
    },
    mounted: function () {
      console.log('child mounted 掛載結(jié)束狀態(tài)===============》');
    },
    beforeUpdate: function () {
      console.log('child beforeUpdate 更新前狀態(tài)===============》');
    },
    updated: function () {
      console.log('child updated 更新完成狀態(tài)===============》');
    },
    beforeDestroy: function () {
      console.log('child beforeDestroy 銷毀前狀態(tài)===============》');
    },
    destroyed: function () {
      console.log('child destroyed 銷毀完成狀態(tài)===============》');
    },
    data() {
      return {
        msg: 'Welcome to Your Vue.js App'
      }
    }
  }
</script>

初始化效果如圖:


父子組件初始化

當(dāng)父組件data改變的時(shí)候:


父組件data改變

當(dāng)子組件data改變的時(shí)候:
子組件data改變的時(shí)候

當(dāng)銷毀子組件的時(shí)候:


當(dāng)銷毀子組件的時(shí)候

當(dāng)父組件被銷毀的時(shí)候
當(dāng)父組件被銷毀的時(shí)候

當(dāng)父組件改變傳給子組件的props值的時(shí)候
當(dāng)父組件改變傳給子組件的props值

總結(jié):
1、 僅當(dāng)子組件完成掛載后叔汁,父組件才會(huì)掛載
2统求、當(dāng)子組件完成掛載后,父組件會(huì)主動(dòng)執(zhí)行一次beforeUpdate/updated鉤子函數(shù)(僅首次)

3据块、父子組件在data變化中是分別監(jiān)控的码邻,但是在更新props中的數(shù)據(jù)是關(guān)聯(lián)的
4、銷毀父組件時(shí)另假,先將子組件銷毀后才會(huì)銷毀父組件

六像屋、說在最后

可能有很多人都不會(huì)理解我為什么會(huì)花一個(gè)晚上的時(shí)候去整理這個(gè)東西,但是在我們的眼中每個(gè)程序員的能力并沒有太大的差距边篮,或者說我沒有能力做的比別人好就只能把基礎(chǔ)打的比別人牢了己莺。好了,又到凌晨了戈轿,去洗澡了

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末篇恒,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子凶杖,更是在濱河造成了極大的恐慌胁艰,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,695評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件智蝠,死亡現(xiàn)場(chǎng)離奇詭異腾么,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)杈湾,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,569評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門解虱,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人漆撞,你說我怎么就攤上這事殴泰。” “怎么了浮驳?”我有些...
    開封第一講書人閱讀 168,130評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵悍汛,是天一觀的道長。 經(jīng)常有香客問我至会,道長离咐,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,648評(píng)論 1 297
  • 正文 為了忘掉前任,我火速辦了婚禮宵蛀,結(jié)果婚禮上昆著,老公的妹妹穿的比我還像新娘。我一直安慰自己术陶,他們只是感情好凑懂,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,655評(píng)論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著梧宫,像睡著了一般瘦棋。 火紅的嫁衣襯著肌膚如雪味咳。 梳的紋絲不亂的頭發(fā)上钝侠,一...
    開封第一講書人閱讀 52,268評(píng)論 1 309
  • 那天佣蓉,我揣著相機(jī)與錄音,去河邊找鬼馆铁。 笑死跑揉,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的埠巨。 我是一名探鬼主播历谍,決...
    沈念sama閱讀 40,835評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼辣垒!你這毒婦竟也來了望侈?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,740評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤勋桶,失蹤者是張志新(化名)和其女友劉穎脱衙,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體例驹,經(jīng)...
    沈念sama閱讀 46,286評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡捐韩,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,375評(píng)論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了鹃锈。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片荤胁。...
    茶點(diǎn)故事閱讀 40,505評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖屎债,靈堂內(nèi)的尸體忽然破棺而出仅政,到底是詐尸還是另有隱情,我是刑警寧澤盆驹,帶...
    沈念sama閱讀 36,185評(píng)論 5 350
  • 正文 年R本政府宣布圆丹,位于F島的核電站,受9級(jí)特大地震影響召娜,放射性物質(zhì)發(fā)生泄漏运褪。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,873評(píng)論 3 333
  • 文/蒙蒙 一玖瘸、第九天 我趴在偏房一處隱蔽的房頂上張望秸讹。 院中可真熱鬧,春花似錦雅倒、人聲如沸璃诀。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,357評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽劣欢。三九已至,卻和暖如春裁良,著一層夾襖步出監(jiān)牢的瞬間凿将,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,466評(píng)論 1 272
  • 我被黑心中介騙來泰國打工价脾, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留牧抵,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,921評(píng)論 3 376
  • 正文 我出身青樓侨把,卻偏偏與公主長得像犀变,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子秋柄,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,515評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容

  • 這篇筆記主要包含 Vue 2 不同于 Vue 1 或者特有的內(nèi)容获枝,還有我對(duì)于 Vue 1.0 印象不深的內(nèi)容。關(guān)于...
    云之外閱讀 5,052評(píng)論 0 29
  • Vue 框架的入口就是 Vue 實(shí)例骇笔,其實(shí)就是框架中的 view model 省店,它包含頁面中的業(yè)務(wù) 處理邏輯、數(shù)據(jù)...
    云中一樵夫閱讀 1,089評(píng)論 0 1
  • 流淌在歲月里的經(jīng)典曲目未曾更改笨触,而今旋律再次響起別有一番味道懦傍。高中的時(shí)候最愛哼唱?jiǎng)⑷粲⒌母瑁牭枚裥瘢瑓s用了整整七年...
    年華深意何處尋閱讀 175評(píng)論 0 0
  • 本書小史耳谎脯,研究中國哲學(xué),以為導(dǎo)引可也持寄≡此螅——馮友蘭 1947年6月賓大 背景 此書為馮友蘭先生1947年美國賓州大...
    止末閱讀 647評(píng)論 0 1
  • 終音未來 終音ミク原名初音ミク00,是初音ミク01開發(fā)前的測(cè)試版本稍味,后來因感染上一種不知名病毒程序后废麻,讓開發(fā)者以為...
    莉蘿艾500閱讀 4,398評(píng)論 0 2