深入理解vue.js——元件
熟悉vue或者研究過vue原始碼的同學都知道,元件是vue最重要的部分之一,而寫元件由兩種常見的方式:
template模板
render渲染函式式的
template式的元件
template式的元件有兩種常見的形式:
第一種:
{{ msg }}Vue.component('hello', { data() { return { msg: 'hello world.' } } })
第二種:
Vue.component('hello', { data() { return { msg: 'hello world.' } }, template: `{{ msg }}` })
在專案開發中,第一種比較常見。
render渲染函式元件
同樣,vue本身也提供了效能更高的render函式渲染的元件。
Vue.component('hello', { data() { return { msg: 'hello world.' } }, render: function(el) { return el( 'div', this.msg ) } })
關於render的用法,可以參考vue.js官方文件介紹。
關於render的示例,可以參考bootstrap-vue的原始碼,它的元件很多都是使用render的。
render函式渲染 VS template模板
後者適合邏輯簡單,前者適合複雜邏輯。
後者屬於宣告是渲染,前者屬於自定Render函式。宣告式渲染,使用者理解起來相對容易,但靈活性不足;自定義render函式靈活性高,但對使用者要求較高。
前者的效能較高,後者效能較低。這一點我們可以看一下,下圖中vue元件渲染的流程圖可知。
基於上一點,我們透過vue元件渲染流程圖知道,使用render函式渲染沒有編譯過程,相當於使用者直接將程式碼給程式。所以,使用它對使用者要求高,且易出現錯誤。
vue元件渲染的流程圖
特殊元件
在vue中有一個特殊的元件,示例程式碼如下:
var vm = new Vue({ data() { return { msg: 'hello world.' } }, el: '#app'})
這個特殊的元件指定我們使用vue的容器,並初始化一些資料。
虛擬DOM
虛擬DOM是vue.js的核心概念之一,vue.js使用js模擬DOM原型樹,這就是我們常掛在嘴邊的VNode。
vue.js發現模板的資料發生改變(vue是資料驅動的框架,這也是MVVM與傳統的DOM結構驅動的區別),將會生成新的虛擬DOM,vue.js透過Diff演算法來對比跟原來的Vnode是否相同來決定是否渲染該虛擬DOM,不相同則渲染。同時,vue2.x支援服務端的渲染。
後續可能還會繼續修改,也歡迎各位批評指正。有問題或者有其他想法的可以在我的上pr。
作者:緣自世界
連結:
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/4422/viewspace-2814282/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Vue.js 深入理解 computed 與 watchVue.js
- 深入理解vue元件Vue元件
- Vue元件深入理解--插槽Vue元件
- 深入理解 React 高階元件React元件
- 深入理解Flutter的GestureDetector元件Flutter元件
- 深入理解Flutter的Listener元件Flutter元件
- [譯] 深入理解 React 高階元件React元件
- 深入淺出理解 React高階元件React元件
- 深入理解 Vue 3 元件通訊Vue元件
- 深入理解Vue元件3大核心概念Vue元件
- 【AAC 系列四】深入理解架構元件:ViewModel架構元件View
- 【AAC 系列三】深入理解架構元件:LiveData架構元件LiveData
- 深入理解flutter的程式碼結構:元件Flutter元件
- 說說 Vue.js 元件Vue.js元件
- vue.js元件開發Vue.js元件
- 【AAC 系列二】深入理解架構元件的基石:Lifecycle架構元件
- Vue.js子元件向父元件通訊Vue.js元件
- Vue.js 動態元件與非同步元件Vue.js元件非同步
- 深入理解Windows Phone 8.1 UI控制元件程式設計WindowsUI控制元件程式設計
- 時間軸元件 by Vue.js元件Vue.js
- 淺嘗Vue.js元件(二)Vue.js元件
- Vue.js 動態元件使用Vue.js元件
- 動態Vue.js佈局元件Vue.js元件
- 深入理解四大元件(四)Service 的繫結過程元件
- 深入理解margin
- 深入理解ReactReact
- 深入理解KVO
- 深入理解 ReentrantLockReentrantLock
- 深入理解 PWA
- 深入理解BFC
- 深入理解volatile
- 深入理解MVCMVC
- 深入理解 TypeScriptTypeScript
- 深入理解JSCoreJS
- 深入理解JavaScriptCoreJavaScript
- 深入理解Isolate
- 深入理解 JVMJVM
- 深入理解HashMapHashMap