簡介(Introduction)
Vue.js是什麼?
- 一個用來搭建使用者介面的框架
框架(Framework):由包含各種功能與開發規則的函數庫組成。我們可以利用其提供的功能加速開發,不必從零開始;而其開發規則通常是經過驗證的良好開發方法,只要follow它,就可以避免很多問題與錯誤。因此框架通常有著加速開發並易於維護的特性。
- 在MVVM的架構下以視圖(view layer)為核心的網頁介面(Web UI)開發方法
- 容易上手並且容易整合進其他的資料庫或是其他的現存的專案
- 可以完美的強化單頁應用程式是(SPA)藉著一些現代工具以及輔助使用的資料庫
安裝使用(Getting Started)
這份官方手冊需要有HTML, CSS, and JavaScript基本知識必較容易讀懂
有其他框架使用經驗也有幫助
相容性指示(Compatibility Note)
- Vue不支援IE8甚至更低的版本
- 因為Vue使用ECMAScript 5 features但IE8不支援
語意化的版本控制
簡單來說就讓版本名稱具有意義好辨識並且達成共識,避免相容性出現問題
最新版本釋出
Vue 開發工具(Vue Devtools)
相當推薦使用在一個使用者友善介面下,可以更好的檢視你的作品以及幫忙debug
使用<script>
引入使用Vue
建議開發的時候引入Development Version才不會省略掉一些常見的錯誤訊息
內容傳遞網路 (CDN - Content delivery network)
作為原型或是學習使用
1 | <script src="https://cdn.jsdelivr.net/npm/vue@2.6.12/dist/vue.js"></script> |
要用在產品身上則推薦使用特定的版本,因為最新版本可能尚未完善
1 | <script src="https://cdn.jsdelivr.net/npm/vue@2.6.12"></script> |
使用原生ES Module相容的版本
1 | <script type="module"> |
可以從此處瀏覽原始碼
小提醒
在你要發布的網站上面可以使用vue.min.js
取代vue.j
可以優化檔案大小以及執行速度
NPM
當要使用在大型規模的app時推薦使用NPM,因為可以跟Webpack or Browserify相容的很好,
1 | # latest stable |
CLI
使用官方CLI需要一些node.js的相關知識
Explanation of Different Builds
在NPM package 原始碼 dist/處有很多不同的builds下方是他們的不同之處:
UMD | CommonJS | ES Module (for bundlers) | ES Module (for browsers) | |
---|---|---|---|---|
Full | vue.js | vue.common.js | vue.esm.js | vue.esm.browser.js |
Runtime-only | vue.runtime.js | vue.runtime.common.js | vue.runtime.esm.js | - |
Full (production) | vue.min.js | - | - | vue.esm.browser.min.js |
Runtime-only (production) | vue.runtime.min.js | - | - | - |
名詞解釋(Term)
Full: 包含Compiler, Runtime
Compiler: 負責編譯模板字版進去JS呈現相關的函式
Runtime: 負責Vue instances, 呈現以及修補 virtual DOM(基本上處理Compiler以下的事情)
UMD: UMD相關的builds可以直接使用在瀏覽器下藉著
<script>
tag
UMD (Universal Module Definition),就是一種javascript通用模塊定義規範,讓你的模塊能在javascript所有運行環境中發揮作用。CommonJS: 給browserify or webpack使用
ES Module:
2.6Vue版本後才開始提供下面兩種builds
- ESM for bundlers: 給webpack 2 or Rollup使用
- ESM for browsers (2.6+ only): 直接引入現代的瀏覽器使用
<script type="module">
宣告式渲染(Declarative Rendering)
Vue.js的核心藉著好理解的模板語法讓使用者把資料呈現到DOM上面
範例
index.html
1 | <div id="app"> |
index.js
1 | var app = new Vue({ |
- 資料以及DOM已經做了連結並且是隨時反應的
ex. app.message修改內容後輸出內容也會即時更改 - 不需要再跟HTML互動,直接在Vue instance就可以操作DOM
範例二
index.html
1 | <div id="app-2"> |
index.js
1 | var app2 = new Vue({ |
當hover的時候在當前的string會顯示 字串+載入日期時間
v-bind
這個有v前墜屬性被稱做指示(directive),是Vue提供使用的,而這個v-bind的用法在於讓這個title的屬性隨著message屬性作同步修在Vue instance上面
所以當我使用下面的方法時,title的屬性也會及時更新
1 | app2.message = 'some new message' |
條件式以及迴圈(Conditionals and Loops)
條件式
index.html
1 | <div id="app-3"> |
index.js
1 | var app3 = new Vue({ |
v-if
可以理解成 v-if後方的文字必須為true(然而是否為true則要去看js程式碼如何操作),才會讓span內的文字被看見
因此當判斷式內容改成flase時,就看不見文字
1 | app-3.seen = false; |
迴圈
index.html
1 | <div id="app-4"> |
index.js
1 | var app4 = new Vue({ |
v-for
可以用來製作清單類型的呈現
如果想要再加入新的清單可以這樣做
1 | app4.todos.push({ text: 'New item' }) |
處理使用者的輸入(Handling User Input)
範例
index.html
1 | <div id="app"> |
index.js
1 | var app = new Vue({ |
v-on:click
跟使用者互動藉由v-on 指示來連接事件監聽click並觸發函式來處理
點擊按鈕後把文字順序反過來
建構組件(Composing with Components)
為了建構大型專案藉著拆分成不同的小組件的優點
- 可重複利用
- 是獨立的組件
- 容量小
範例
index.js
1 | // 定義一個新的組件 todo-item |
index.html
1 | <div id="app"> |
首先在js先撰寫組件todo-item後就可以在html裡面直接使用
範例二
index.js
1 | Vue.component('todo-item', { |
index.html
1 | <div id="app-7"> |
- 首先於component處新增
porp
是一個可以客製化的屬性並命名todo - 介下來使用
v-bind
讓文字可以被動態的傳入DOM同時傳入key的部分會在後面章節作解釋 - 並且使用
v-for
製作清單列表
在大型專案中把內部的app做拆分是必要的,讓開發過程容易管理,下面程式碼是個範例說明比較多組件且複雜的html長相
1 | <div id="app"> |
與自定義元素的關係(Relation to Custom Elements)
Vue的組件非常類似於Custom Elements
Slot是存在web component内部的占位符,用户可以通過slot屬性在web component的内部插入自定義的標記文本。
- 不同之處
- Web Components規範已經完成通過但是依舊沒有被所有瀏覽器支援
(目前 Safari 10.1+、Chrome 54+ 和 Firefox 63+ 原生支持 Web Components) - Vue 组件不需要任何 polyfill,並且支援所有瀏覽器 (IE9以下不支援),必要時Vue组件也可以包裝於原生自定義元素之内
polyfill代指為舊瀏覽器實現或模擬現有版本已實現之功能的程式碼片段
- Vue 组件提供了Custom Elements沒有的功能,跨组件數據流、自定義事件溝通以及bulid整合工具。
- Vue 並沒有使用Custom Elements,不過在應用以及發布Custom Elements上還是有很好的互通性,Vue CLI 也支持 Vue 组件建構成為原生的Custom Elements