Vue.js 系列教程 3:Vue-cli,生命周期鉤子

来源:http://www.cnblogs.com/nzbin/archive/2017/02/12/6380663.html
-Advertisement-
Play Games

原文:intro-to-vue-3-vue-cli-lifecycle-hooks 譯者:nzbin 這是 JavaScript 框架 Vue.js 五篇教程的第三部分。在這一部分,我們將學習 Vue-cli ,還會涉及真實的開發流程。這不是一個完整的指南,而是基礎知識的概述,所以你可以瞭解 Vue ...


原文:intro-to-vue-3-vue-cli-lifecycle-hooks

譯者:nzbin

這是 JavaScript 框架 Vue.js 五篇教程的第三部分。在這一部分,我們將學習 Vue-cli ,還會涉及真實的開發流程。這不是一個完整的指南,而是基礎知識的概述,所以你可以瞭解 Vue.js 以及它的用途。

系列文章:

  1. 渲染, 指令, 事件
  2. 組件, Props, Slots
  3. Vue-cli (你在這!)
  4. Vuex (耐心等待!)
  5. 動畫 (耐心等待!)

Vue-cli 和構建過程

如果你還沒有讀過上一部分關於 Vue.js 組件和 props 的內容,我強烈建議你在讀這篇文章之前先讀讀上一部分,另外,部分內容缺乏語境。

Vue 提供了一個好用的 命令行工具 ,你可以選擇一些構建工具啟動項目, 還提供了簡單的啟動模板。這是個非常好的工具。在安裝 vue-cli 之前,需要檢查 node 的版本,以及升級 npm 或者 yarn 。首先要安裝 vue-cli ( -g 表示全局安裝 )

$ npm install -g vue-cli

有多種構建工具可供選擇,但是在我們的例子中將使用 webpack:

$ vue init webpack <project-name>

可以通過命令行進入目錄安裝所有內容,設置 `package.json` 文件,然後通過以下命令在 localhost:8080 埠啟動本地服務:

$ npm run dev

程式運行成功!我喜歡這種簡單的設置。你可以從 `/src/` 目錄下的 APP 文件以及 `/components/`目錄下的 `Hello.vue`文件開始項目。這非常好,因為你已經看到如何建立文件,以及如何進行文件的導入導出。

先看一下 `.vue` 這個文件擴展名,因為你還沒有使用過 vue,所以你之前也沒有遇到這種文件。

在 `.vue` 文件中,可以放任何組件內容。我們不需要再用 <script type="text/x-template"> 包裹模板,現在我們將按下麵的邏輯創建更具有語義化的文件:

<template>
  <div>
     <!-- Write your HTML with Vue in here -->    
  </div>
</template>

<script>
  export default {
     // Write your Vue component logic here
  }
</script>

<style scoped>
  /* Write your styles for the component in here */
</style>

我針對 Sublime Text 建立了一個  Vue snippets 的倉庫 ,可以針對 `.vue` 文件快速生成上述模板 ( 這是 vbase snippet 輸出的 )。 這個 是針對 atom 的 ( 它指出 Vue 需要 1+ 的版本,而 Vue 現在是 v2),還有 這個 是針對 vscode 的。

這裡要註意的幾件事: 和 React 一樣,必須返回一個閉合的標簽,在這裡我使用一個 div 。在SVG中我也使用 <g> 元素。任何標簽都可以,但是整個模板必須包裹在一個標簽中。

你註意到我們在這裡將使用 export default 編寫腳本,比如之前使用的 data function 或者 methods ,但是如果我們想在這個 `.vue` 文件中使用子組件,我們需要導入 import 它們 ( 之後詳細介紹 )。

你也會註意到在樣式標簽中有一個特殊的 scoped 屬性值。這使我們能夠很容易地將此組件的樣式僅限於此組件。我們也會使用 <style> ,它將創建整個程式的樣式。我通常會為應用程式創建一個通用的樣式表,包括像 fonts 和 line-heights 的共同樣式, 所以我將藉助 vue-style-loader 導入 @import 到 App.vue 文件的 <style> 標簽中。我也會使用 <style scoped> 標簽為模板制定特殊的樣式,但是只對當前模板有效! Vue-cli 的好處就是讓你自己決定如何組織文件,而且你不必添加其它的依賴或模塊來限制樣式的作用範圍。

之前簡答地介紹了 slots ,當我們在 Vue 組件中通過局部樣式標簽使用 slots 時,它們適用於具有 slots 的組件。這是非常有用的,因為你可以很容易地切換組件和改變樣式。

在開發過程中,使用特殊的 `.vue` 文件來組織 HTML,styles 和 JS 非常有幫助。我喜歡完全分離的方式,可以很清楚地看到每一部分,我還不適應這種緊密聯繫在一起的方式。它可以加快我的開發,而且我發現這種標記語言是語義化的。

你可能註意到語法高亮並不能自動識別 `.vue` 文件,所以我在 Sublime Text 中安裝了 這個

下麵是將組件 導入/導出 文件的基本方式 ( 在 vue-sublime snippets 中是 vimport:c ):

import New from './components/New.vue';

export default {
  components: {
    appNew: New
  }
}

舉一個生活中的例子,看一下上次我們用過的酒瓶標簽的案例,它的組件有兩個獨立的模板:

App.vue:

<template>
  <div class="container">

  <main>
      <component :is="selected">
        <svg class="winebottle" aria-labelledby="title" xmlns="http://www.w3.org/2000/svg" viewBox="0 155 140 300">
          ...
      </svg>
      </component>
    </main>

    <aside>
      <h4>Name your Wine</h4>
      <input v-model="label" maxlength="18">
      <div class="button-row">
        <h4>Color</h4>
        <button @click="selected ='appBlack', labelColor = '#000000'">Black Label</button>
        <button @click="selected ='appWhite', labelColor = '#ffffff'">White Label</button>
        <input type="color" v-model="labelColor" defaultValue="#ff0000">
      </div>
    </aside>

  </div>
</template>

<script>
  import Black from './components/Black.vue'
  import White from './components/White.vue'
  ...
  export default {
      data: function () {
        return {
          selected: 'appBlack',
          label: 'Label Name',
          ...
        };
      },
      components: {
          appBlack: Black,
          appWhite: White,
          ...
      }
  }
</script>

<style>
  @import "./assets/style.css";
</style>

黑色組件:

<template>
  <div>
    <slot></slot>
  </div>
</template>

<style scoped>
  .label {
    fill: black;
  }
  .bottle, .wine-text {
    fill: white;
  }
  .flor {
    fill: #ccc;
  }
  .bkimg {
    filter:url(#inverse)
  }
</style>

註意我在這裡給組件中的 slot 設置了不同的樣式,這是很好的工作方式,但這隻是一種方法。通過 components,slots 和 props 構建程式的方法還有很多。這裡的代碼也只顯示了部分內容。我建立了該示例的 倉庫 ,使用 Vue-cli 構建的。為了熟悉工作流程,我強烈建議使用 Vue-cli 構建組件以及通過 props 傳遞狀態。只要完成初始設置,這種方式直觀而且快速。

生命周期鉤子

在討論生命周期鉤子之前,需要回顧一下我在第一篇文章中提到的虛擬 DOM。我提到 Vue.js 具有虛擬 DOM,但沒有說明它的用途。

當你使用像 jQuery 的框架工作時,你可能聽說過 DOM 並且通過 DOM 更新改變內容。最後,我們花了大量的時間來檢查 DOM 在做什麼並存儲狀態。相反,虛擬 DOM 是 DOM 的抽象表示,有點像複製品,但在這種情況下,它將是主副本。在這個系列文章中,當我們用 Vue 的方式使用狀態時,我們創建狀態並觀察狀態的更新。

當一個 Vue 實例更新後,Vue 將會檢查它是否與之前的有不同之處。如果確實有不同,Vue 將會調用生命周期的方法,更新 DOM 變化的部分。這是為了提高效率,這種方式下,DOM 只更新需要的部分。

生命周期鉤子提供了一些 方法 ,因此你可以在組件生命周期的不同時刻精確地觸發某些操作。當我們將組件實例化時,組件會被創建,反之會被銷毀,比如當我們使用 v-if/v-else 指令切換時。

可以使用的鉤子有: beforeCreate, created, beforeMount, mounted, beforeUpdate, updated, activated, deactivated, beforeDestroy, destroyed 。如果你想深入瞭解,可以看看 介紹每種方法 的 API 文檔。下麵的小例子展示了部分工作原理(檢查控制台):

const Child = {
  template: '#childarea',
  beforeCreate() {
    console.log("beforeCreate!");
  }, 
 ...
};

new Vue({
  el: '#app',
  data() {
    return {
      isShowing: false 
    }
  },
  methods: {
    toggleShow() {
      this.isShowing = !this.isShowing;
    }
  },
  components: {
    appChild: Child
  }
});
<div v-if="isShowing">
  <app-child></app-child>
</div>

See the Pen lifecycle hooks shown in a child component by Sarah Drasner (@sdras) on CodePen.

註意我們在這裡使用了 v-if 而沒有使用 v-show ,因為 v-if 會真實的創建或者銷毀組件,而 v-show 只是切換可見性(組件仍然存在於 DOM 中)。同樣的, <keep-alive></keep-alive> 也不會創建或者銷毀, 而是激活或停用—— 因為組件仍然存在,只是沒有使用。

正如組件中的方法會自動綁定 this,生命周期鉤子也會自動綁定實例,所以可以使用組件的狀態和方法。仍然不需要通過 console.log 查看 this 的指向! *heartiest eyes* 儘管如此,你不應該在生命周期方法中使用箭頭函數,因為它會綁定父類上下文,而不是 Vue 實例。

在下麵的例子中,當組件最初被創建時,會有大量的元素被移動,所以我將使用 mounted 鉤子函數為每一個組件觸發相應的動畫。你可以點擊右下角的 return 按鈕來看啟動動畫。

See the Pen Vue Weather Notifier by Sarah Drasner (@sdras) on CodePen.

mounted() {
    let audio = new Audio('https://s3-us-west-2.amazonaws.com/s.cdpn.io/28963/rain.mp3'),
        tl = new TimelineMax();

    audio.play();
    tl.add("drops");

    //drops in
    tl.staggerFromTo("#droplet-groups g path", 0.3, {
      drawSVG: "0% -10%"
    }, {
      drawSVG: "100% 110%",
      repeat: 3,
      repeatDelay: 1,
      ease: Sine.easeIn
    }, 0.5, "drops");
 …
}

在這個例子中我使用了很多 Vue 提供的漂亮且複雜的 <transition><transition-group> 組件,我將在系列文章的最後一部分 Animation 中介紹它們,以及為什麼及何時使用。


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

-Advertisement-
Play Games
更多相關文章
  • 在進行業務軟體開發的時候,都會涉及到許可權控制的問題,asp.net core mvc提供了相關特性。 在具體介紹使用方法前,我們需要先瞭解幾個概念: 1,claim:英文翻譯過來是聲明的意思,一個claim包含Type,Value兩項信息。我把claim理解成一個許可權的定義,比如Type=會員,Va ...
  • 有這麼一種應用場景: 你是做前端或APP開發的,需要調用服務端提供的介面,介面只能在公司內網訪問;在公司外就無法調試代碼了。 想在公司外訪問怎麼辦呢? 如果在公司的時候將所有介面的響應內容都保存起來,就可以脫離服務端在本地模擬出來一個服務端環境,從而就可以不受網路環境的限制愉快的調試代碼了。 ...
  • 利用周末的時間讀了潘加宇的《軟體方法(上)》,希望梳理清楚UML的知識脈絡; 利潤=需求-設計 利潤=需求-設計 利潤=需求-設計 利潤=需求-設計 缺乏清晰、共用的願景往往是項目失敗的主要原因。 願景回答這樣一個問題:在老大看來,引進這個系統的目的是什麼? 尋找老大: 要點:老大是買方。典型錯誤: ...
  • //判斷右表是否為空併為映射表進行賦值標誌var query=from q in product join m in favProduct on q.Name equals m.Name into t from x in t.DefalultEmpty() select new { Name=q.N ...
  • 只要將數據放入model中, 也能取到值,原因是model臨時放入session域中,當從定向到另一個url時,底層把數據拼接在url地址後面(重定向一定是get請求方式),同時將session域中的這條數據清除,重定向到conttoller時,取值方式只有request.getParameter( ...
  • compass 是sass的一個工具庫 compass在sass 的基礎上封裝了一系列有用的模塊,用來補充和豐富sass的工能, 安裝: compass是用 ruby語言開發的,所以安裝它之前必須安裝ruby。 命令: gem install compass 項目初始化: 要創建一個你的Compas ...
  • 前言 之前用 npm 安裝過 nvm,就以為安裝成功了,但運行 nvm 就報如下提示: This is not the package you are looking for: please go to http://nvm.sh 安裝NVM 查資料得出,要使用 curl 或 wget 來安裝... ...
  • 如今前端界angular react vue三大框架並駕齊驅,其中有一個共同點就是組件化開發,這也符合w3c 推行Web Components的趨勢。現如今不懂組件化開發的前端絕對不是好廚子。跳槽新公司pc端使用angular1.5的Components比較多,趁著入職前幾天自己看一下。 由於ang ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...