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

vue生命周期和react生命周期對(duì)比【推薦】

 更新時(shí)間:2018年09月19日 10:20:50   作者:文博的博客  
本文通過(guò)實(shí)例代碼給大家介紹了vue生命周期和react生命周期對(duì)比 ,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

個(gè)人認(rèn)為,react和vue的業(yè)務(wù)邏輯是差不多,vue在react上封裝了更簡(jiǎn)潔的方法,使用起來(lái)更加的便捷,如:提供了便捷的指令(v-for,v-if,v-model),還提供了更多的屬性(computed,watch),我還是比較喜歡用react的,更接近js原生,更容易于理解它。

一 vue的生命周期如下圖所示(很清晰)初始化、編譯、更新、銷毀

二 vue生命周期的栗子

 注意觸發(fā)vue的created事件以后,this便指向vue實(shí)例,這點(diǎn)很重要

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8">
    <title>vue生命周期</title>
    <script src="../js/vue.js"></script>
    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
  </head>
  <body>
    <div class="test" style="border: 1px black dashed;padding: 8px;">
      {{a}}
    </div>
    <div class="test2" style="border: 1px red solid;margin-top: 10px;padding: 8px;">
      我是內(nèi)容二
    </div>
    <script type="text/javascript">
      var myVue = new Vue({
        el: ".test",
        data: {
          a: "我是內(nèi)容,在控制臺(tái)輸入myVue.a=123456,可以改變我的值"
        },
        created: function () { 
          //在實(shí)例創(chuàng)建之后同步調(diào)用。此時(shí)實(shí)例已經(jīng)結(jié)束解析選項(xiàng),這意味著已建立:數(shù)據(jù)綁定,計(jì)算屬性,方法,watcher/事件回調(diào)。
          //但是還沒(méi)有開(kāi)始 DOM 編譯,$el 還不存在,但是實(shí)例存在,即this.a存在,可打印出來(lái) 。
          console.log("建立");
        },
        beforeCompile: function () {
          console.log("未開(kāi)始編譯");
        },
        compiled: function () { 
          //在編譯結(jié)束后調(diào)用。此時(shí)所有的指令已生效,因而數(shù)據(jù)的變化將觸發(fā) DOM 更新。但是不擔(dān)保 $el 已插入文檔。
          console.log("編譯完成");
        },
        ready: function () { 
          //在編譯結(jié)束和 $el 第一次插入文檔之后調(diào)用,如在第一次 attached 鉤子之后調(diào)用。注意必須是由 Vue 插入(如 vm.$appendTo() 等方法或指令更新)才觸發(fā) ready 鉤子。
          console.log("一切準(zhǔn)備好了");
        },
        attached :function () { //myVue.$appendTo(".test2")暫時(shí)觸發(fā)不了,不知道怎么解決
          //在 vm.$el 插入 DOM 時(shí)調(diào)用。必須是由指令或?qū)嵗椒ǎㄈ?$appendTo())插入,直接操作 vm.$el 不會(huì) 觸發(fā)這個(gè)鉤子。
          console.log("插入DOM成功");
        },
        detached :function () { //觸發(fā)事件 myVue.$destroy(true),其中參數(shù)true控制是否刪除DOM節(jié)點(diǎn)或者myVue.$remove()
          //在 vm.$el 從 DOM 中刪除時(shí)調(diào)用。必須是由指令或?qū)嵗椒▌h除,直接操作 vm.$el 不會(huì) 觸發(fā)這個(gè)鉤子。
          console.log("刪除DOM成功");
        },
        beforeDestroy: function () { //觸發(fā)方式,在console里面打myVue.$destroy();
          //在開(kāi)始銷毀實(shí)例時(shí)調(diào)用。此時(shí)實(shí)例仍然有功能。
          console.log("銷毀前");
        },
        destroyed: function () {  //觸發(fā)方式,在console里面打myVue.$destroy();其中myVue.$destroy(true)是刪除DOM節(jié)點(diǎn),會(huì)觸發(fā)detached函數(shù),但是實(shí)例仍然存在
          //在實(shí)例被銷毀之后調(diào)用。此時(shí)所有的綁定和實(shí)例的指令已經(jīng)解綁,注意是解綁不是銷毀,所有的子實(shí)例也已經(jīng)被銷毀。
          console.log("已銷毀");
        }
    });
    </script>
  </body>
</html>

一、react生命周期

React 生命周期分為三種狀態(tài) 1. 初始化 2.更新 3.銷毀

•初始化

1、getDefaultProps()

設(shè)置默認(rèn)的props,也可以用ufaultProps設(shè)置組件的默認(rèn)屬性.

2、getInitialState()

在使用es6的class語(yǔ)法時(shí)是沒(méi)有這個(gè)鉤子函數(shù)的,可以直接在constructor中定義this.state。此時(shí)可以訪問(wèn)this.props

3、componentWillMount()

組件初始化時(shí)只調(diào)用,以后組件更新不調(diào)用,整個(gè)生命周期只調(diào)用一次,此時(shí)可以修改state。

4、 render()

react最重要的步驟,創(chuàng)建虛擬dom,進(jìn)行diff算法,更新dom樹(shù)都在此進(jìn)行。此時(shí)就不能更改state了。

5、componentDidMount()

組件渲染之后調(diào)用,只調(diào)用一次。

•更新

6、componentWillReceiveProps(nextProps)

組件初始化時(shí)不調(diào)用,組件接受新的props時(shí)調(diào)用。

7、shouldComponentUpdate(nextProps, nextState)

react性能優(yōu)化非常重要的一環(huán)。組件接受新的state或者props時(shí)調(diào)用,我們可以設(shè)置在此對(duì)比前后兩個(gè)props和state是否相同,如果相同則返回false阻止更新,因?yàn)橄嗤膶傩誀顟B(tài)一定會(huì)生成相同的dom樹(shù),這樣就不需要?jiǎng)?chuàng)造新的dom樹(shù)和舊的dom樹(shù)進(jìn)行diff算法對(duì)比,節(jié)省大量性能,尤其是在dom結(jié)構(gòu)復(fù)雜的時(shí)候

8、componentWillUpdata(nextProps, nextState)

組件初始化時(shí)不調(diào)用,只有在組件將要更新時(shí)才調(diào)用,此時(shí)可以修改state

9、render()

組件渲染

10、componentDidUpdate()

組件初始化時(shí)不調(diào)用,組件更新完成后調(diào)用,此時(shí)可以獲取dom節(jié)點(diǎn)。

•卸載

11、componentWillUnmount()

組件將要卸載時(shí)調(diào)用,一些事件監(jiān)聽(tīng)和定時(shí)器需要在此時(shí)清除。

總結(jié)

以上所述是小編給大家介紹的vue生命周期和react生命周期對(duì)比,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • vuex實(shí)現(xiàn)及簡(jiǎn)略解析(小結(jié))

    vuex實(shí)現(xiàn)及簡(jiǎn)略解析(小結(jié))

    這篇文章主要介紹了vuex實(shí)現(xiàn)及簡(jiǎn)略解析(小結(jié)),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-03-03
  • 在Vue中使用icon 字體圖標(biāo)的方法

    在Vue中使用icon 字體圖標(biāo)的方法

    這篇文章主要介紹了在Vue中使用icon 字體圖標(biāo)的方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-06-06
  • 詳解vue頁(yè)面狀態(tài)持久化詳解

    詳解vue頁(yè)面狀態(tài)持久化詳解

    這篇文章主要為大家介紹了vue頁(yè)面狀態(tài)持久化,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2021-12-12
  • vue實(shí)現(xiàn)導(dǎo)出excel的多種方式總結(jié)

    vue實(shí)現(xiàn)導(dǎo)出excel的多種方式總結(jié)

    在Vue中實(shí)現(xiàn)導(dǎo)出Excel有多種方式,可以通過(guò)前端實(shí)現(xiàn),也可以通過(guò)前后端配合實(shí)現(xiàn),這篇文章將為大家詳細(xì)介紹幾種常用的實(shí)現(xiàn)方式,需要的可以參考下
    2023-08-08
  • Vue build過(guò)程取消console debugger控制臺(tái)信息輸出方法詳解

    Vue build過(guò)程取消console debugger控制臺(tái)信息輸出方法詳解

    這篇文章主要為大家介紹了Vue build過(guò)程取消console debugger控制臺(tái)信息輸出方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-09-09
  • vue組件實(shí)踐之可搜索下拉框功能

    vue組件實(shí)踐之可搜索下拉框功能

    這篇文章主要介紹了vue實(shí)現(xiàn)可搜索的下拉菜單組件功能,在文中通過(guò)實(shí)例代碼給大家補(bǔ)充介紹了vue組件實(shí)踐-可搜索下拉框,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-11-11
  • 使用vue打包時(shí)vendor文件過(guò)大或者是app.js文件很大的問(wèn)題

    使用vue打包時(shí)vendor文件過(guò)大或者是app.js文件很大的問(wèn)題

    這篇文章主要介紹了使用vue打包時(shí)vendor文件過(guò)大或者是app.js文件很大問(wèn)題的解決方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-06-06
  • Vue前端如何實(shí)現(xiàn)生成PDF并下載功能詳解

    Vue前端如何實(shí)現(xiàn)生成PDF并下載功能詳解

    在前端的崗位上經(jīng)常需要實(shí)現(xiàn)個(gè)生成個(gè)并下載的可視化圖表頁(yè)P(yáng)DF文件,這篇文章主要給大家介紹了關(guān)于Vue前端如何實(shí)現(xiàn)生成PDF并下載功能的相關(guān)資料,需要的朋友可以參考下
    2021-10-10
  • vue3使用vue-router的完整步驟記錄

    vue3使用vue-router的完整步驟記錄

    Vue Router是Vue.js (opens new window)官方的路由管理器,它和 Vue.js 的核心深度集成,讓構(gòu)建單頁(yè)面應(yīng)用變得易如反掌,這篇文章主要給大家介紹了關(guān)于vue3使用vue-router的相關(guān)資料,需要的朋友可以參考下
    2021-06-06
  • 詳解vue-cli 構(gòu)建Vue項(xiàng)目遇到的坑

    詳解vue-cli 構(gòu)建Vue項(xiàng)目遇到的坑

    本篇文章主要介紹了詳解vue-cli 構(gòu)建Vue項(xiàng)目遇到的坑,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-08-08

最新評(píng)論