【Vue3 從入門到實(shí)戰(zhàn) 進(jìn)階式掌握完整知識體系】002-Vue語法基礎(chǔ):Vue中的應(yīng)用和組件的基本部分解析、生命周期

二临庇、Vue語法基礎(chǔ)

1零截、Vue中的應(yīng)用和組件的基本部分

代碼

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>基礎(chǔ)語法</title>
  <!-- 引入Vue庫 -->
  <script src="https://unpkg.com/vue@next"></script>
</head>

<body>
  <div id="root"></div>
</body>

<script>
  // 創(chuàng)建一個 vue 應(yīng)用實(shí)例麸塞,給這個實(shí)例起一個名字,叫做“app”
  // 傳入了一個參數(shù)涧衙,這個參數(shù)使用 {} 括起來哪工,表示最外層應(yīng)該如何展示
  // 也就是 vue 應(yīng)用的根組件
  // mvvm 設(shè)計(jì)模式:m -> model 數(shù)據(jù) view -> 視圖 vm -> 視圖數(shù)據(jù)連接層
  // 下面的 data 就是數(shù)據(jù)奥此,是我們自己定義的
  // 下面的 template 就是視圖模板,也是我們自己定義的
  // vm 視圖數(shù)據(jù)連接層是 vue 組件做的
  const app = Vue.createApp({
    data(){
      return{
        message: 'hello world'
      }
    },
    template: '<div>{{message}}</div>'
  });

  // 掛載(綁定)到 id 為 root 的標(biāo)簽
  // 這行代碼的返回值就是 vue 應(yīng)用的根組件
  // 這里的 vm 就是應(yīng)用的根組件
  const vm = app.mount('#root');
</script>

</html>

運(yùn)行結(jié)果

image-20210612112626889.png

2雁比、理解Vue的生命周期函數(shù)*

生命周期圖

圖片來自官方文檔稚虎,注釋是本人參考網(wǎng)上解讀和英文含義寫的,不是特別專業(yè)偎捎,僅作參考蠢终!

lifecycle.png

代碼

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>基礎(chǔ)語法</title>
  <!-- 引入Vue庫 -->
  <script src="https://unpkg.com/vue@next"></script>
</head>

<body>
  <div id="root"></div>
</body>

<script>
  const app = Vue.createApp({
    data(){
      return{
        message: 'hello world'
      }
    },
    // 創(chuàng)建實(shí)例之前執(zhí)行的函數(shù)
    beforeCreate(){
      console.log(this.message, "beforeCreate");
    },
    // 創(chuàng)建實(shí)例之后執(zhí)行的函數(shù)
    created(){
      console.log(this.message, "created");
    },
    // 實(shí)例創(chuàng)建之后,掛載之前執(zhí)行
    beforeMount(){
      console.log(document.getElementById("root").innerHTML,"beforeMount");
    },
    // 掛載之后執(zhí)行茴她,此時數(shù)據(jù)已經(jīng)被綁定到視圖上了
    mounted(){
      console.log(document.getElementById("root").innerHTML,"mounted");
    },
    // 當(dāng)數(shù)據(jù)發(fā)生變化時寻拂,頁面更新前執(zhí)行的函數(shù)
    beforeUpdate(){
      console.log(document.getElementById("root").innerHTML,"beforeUpdate");
    },
    // 當(dāng)數(shù)據(jù)發(fā)生變化時,頁面更新后執(zhí)行的函數(shù)
    updated(){
      console.log(document.getElementById("root").innerHTML,"updated");
    },
    // 當(dāng) vue 應(yīng)用失效時丈牢,且在被銷毀前兜喻,執(zhí)行的函數(shù)
    beforeUnmount(){
      console.log(document.getElementById("root").innerHTML,"updated");
    },
    // 當(dāng) vue 應(yīng)用失效時,且在被銷毀后赡麦,執(zhí)行的函數(shù)
    unmounted(){
      console.log(document.getElementById("root").innerHTML,"updated");
    },
    template: '<div>{{message}}</div>'
  });
  const vm = app.mount('#root');
</script>

</html>

運(yùn)行結(jié)果

image-20210612132524993.png

關(guān)于模板

參考生命周期圖解的7和8朴皆,如果有模板就去編譯,沒有就將所綁定的標(biāo)簽作為模板泛粹,因此可以這樣寫遂铡!

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>基礎(chǔ)語法</title>
  <!-- 引入Vue庫 -->
  <script src="https://unpkg.com/vue@next"></script>
</head>

<body>
  <div id="root">
    <!-- 將頁面內(nèi)容寫到這里 -->
    <div>{{message}}</div>
  </div>
</body>

<script>
  const app = Vue.createApp({
    data(){
      return{
        message: 'hello world'
      }
    }
    // 刪除這里的模板
    // template: '<div>{{message}}</div>'
  });
  const vm = app.mount('#root');
</script>

</html>

Vue3的生命周期函數(shù)圖

de01e730e563406cbf3399861fa23aa4tplv-k3u1fbpfcp-zoom-1.png

Vue3全部的生命周期鉤子與Vue2比較

我們可以看到beforeCreatecreatedsetup替換了(但是 Vue3 中仍然可以使用, 因?yàn)?Vue3 是向下兼容的晶姊, 也就是實(shí)際使用的是 vue2 的)扒接。其次,鉤子命名都增加了on; Vue3.x 還新增用于調(diào)試的鉤子函數(shù)onRenderTriggeredonRenderTricked

3eadd1ec0ac94343951ae2453cf41fcetplv-k3u1fbpfcp-zoom-1.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末们衙,一起剝皮案震驚了整個濱河市钾怔,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌蒙挑,老刑警劉巖宗侦,帶你破解...
    沈念sama閱讀 216,372評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異忆蚀,居然都是意外死亡矾利,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評論 3 392
  • 文/潘曉璐 我一進(jìn)店門馋袜,熙熙樓的掌柜王于貴愁眉苦臉地迎上來男旗,“玉大人,你說我怎么就攤上這事欣鳖〔旎剩” “怎么了?”我有些...
    開封第一講書人閱讀 162,415評論 0 353
  • 文/不壞的土叔 我叫張陵泽台,是天一觀的道長什荣。 經(jīng)常有香客問我呀忧,道長,這世上最難降的妖魔是什么溃睹? 我笑而不...
    開封第一講書人閱讀 58,157評論 1 292
  • 正文 為了忘掉前任而账,我火速辦了婚禮,結(jié)果婚禮上因篇,老公的妹妹穿的比我還像新娘泞辐。我一直安慰自己,他們只是感情好竞滓,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評論 6 388
  • 文/花漫 我一把揭開白布咐吼。 她就那樣靜靜地躺著,像睡著了一般商佑。 火紅的嫁衣襯著肌膚如雪锯茄。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,125評論 1 297
  • 那天茶没,我揣著相機(jī)與錄音肌幽,去河邊找鬼。 笑死抓半,一個胖子當(dāng)著我的面吹牛喂急,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播笛求,決...
    沈念sama閱讀 40,028評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼廊移,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了探入?” 一聲冷哼從身側(cè)響起狡孔,我...
    開封第一講書人閱讀 38,887評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎蜂嗽,沒想到半個月后苗膝,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,310評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡徒爹,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評論 2 332
  • 正文 我和宋清朗相戀三年荚醒,在試婚紗的時候發(fā)現(xiàn)自己被綠了芋类。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片隆嗅。...
    茶點(diǎn)故事閱讀 39,690評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖侯繁,靈堂內(nèi)的尸體忽然破棺而出胖喳,到底是詐尸還是另有隱情,我是刑警寧澤贮竟,帶...
    沈念sama閱讀 35,411評論 5 343
  • 正文 年R本政府宣布丽焊,位于F島的核電站较剃,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏技健。R本人自食惡果不足惜写穴,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評論 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望雌贱。 院中可真熱鬧啊送,春花似錦、人聲如沸欣孤。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽降传。三九已至篷朵,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間婆排,已是汗流浹背声旺。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評論 1 268
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留段只,地道東北人艾少。 一個月前我還...
    沈念sama閱讀 47,693評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像翼悴,于是被迫代替她去往敵國和親缚够。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評論 2 353

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