詳解vue組件基礎(chǔ)
什么是組件
組件(Component)是對數(shù)據(jù)和方法的簡單封裝。web中的組件其實可以看成是頁面的一個組成部分,它是一個具有獨立的邏輯和功能的界面,同時又能根據(jù)規(guī)定的接口規(guī)則進行相互融和,最終成為一個完整的應(yīng)用,頁面就是由一個個類似這樣的組成部分組成的,比如導(dǎo)航、列表、彈窗、下拉菜單等。頁面只不過是這樣組件的容器,組件自由組合形成功能完整的界面,當(dāng)不需要某個組件,或者想要替換某個組件時,可以隨時進行替換和刪除,而不影響整個應(yīng)用的運行。、前端組件化的核心思想就是將一個巨大復(fù)雜的東西拆分成粒度合理的小東西。
使用提高開發(fā)效率、方便重復(fù)使用、簡化調(diào)試步驟、提升整個項目的可維護性、便于協(xié)同開發(fā)。
vue作為一個輕量級前端框架,其核心就是組件化開發(fā)。
組件可以擴展 HTML 元素,封裝可重用的代碼。在較高層面上,組件是自定義元素,Vue.js 的編譯器為它添加特殊功能。在有些情況下,組件也可以表現(xiàn)為用 is 特性進行了擴展的原生 HTML 元素。
vue中,組件是可復(fù)用的 Vue 實例。因為組件是可復(fù)用的 Vue 實例,所以它們與 new Vue 接收相同的選項,例如 data、computed、watch、methods 以及生命周期鉤子等。僅有的例外是像 el 這樣根實例特有的選項。
組件注冊
全局注冊
通過 Vue.component 來創(chuàng)建組件:
Vue.component('my-component-name', { // ... 選項 ... })
這些組件是全局注冊的。也就是說它們在注冊之后可以用在任何新創(chuàng)建的 Vue 根實例 (new Vue) 的模板中。比如:
Vue.component('component-a', { /* ... */ }) Vue.component('component-b', { /* ... */ }) Vue.component('component-c', { /* ... */ }) new Vue({ el: '#app' }) <div id="app"> <component-a></component-a> <component-b></component-b> <component-c></component-c> </div>
在所有子組件中也是如此,也就是說這三個組件在各自內(nèi)部也都可以相互使用。
局部注冊
全局注冊往往是不夠理想的。比如,如果你使用一個像 webpack 這樣的構(gòu)建系統(tǒng),全局注冊所有的組件意味著即便你已經(jīng)不再使用一個組件了,它仍然會被包含在你最終的構(gòu)建結(jié)果中。這造成了用戶下載的 JavaScript 的無謂的增加。
在這些情況下,你可以通過一個普通的 JavaScript 對象來定義組件:
var ComponentA = { /* ... */ } var ComponentB = { /* ... */ } var ComponentC = { /* ... */ }
然后在 components 選項中定義你想要使用的組件:
new Vue({ el: '#app' components: { 'component-a': ComponentA, 'component-b': ComponentB } })
對于 components 對象中的每個屬性來說,其屬性名就是自定義元素的名字,其屬性值就是這個組件的選項對象。
注意局部注冊的組件在其子組件中不可用。例如,如果你希望 ComponentA 在 ComponentB 中可用,則你需要這樣寫:
var ComponentA = { /* ... */ } var ComponentB = { components: { 'component-a': ComponentA }, // ... }
使用Babel和webpack中的注冊組件
import ComponentA from './ComponentA.vue' export default { components: { ComponentA }, // ... }
注意在 ES2015+ 中,在對象中放一個類似 ComponentA 的變量名其實是 ComponentA: ComponentA 的縮寫,即這個變量名同時是:
用在模板中的自定義元素的名稱
包含了這個組件選項的變量名
基礎(chǔ)組件的自動化全局注冊
沒看懂。
data 必須是一個函數(shù)
data: { count: 0 }
這樣定義的data中的變量是全局變量,在使用組件時,在一個組件中修改變量的值,會影響到所有組件中該變量的值。為避免變量干擾,一個組件的 data 選項必須是一個函數(shù),因此每個實例可以維護一份被返回對象的獨立的拷貝:
data: function () { return { count: 0 } }
動態(tài)組件
在不同組件之間進行動態(tài)切換是非常有用的,比如在一個多標(biāo)簽的界面里:
上述內(nèi)容可以通過 Vue 的 <component> 元素加一個特殊的 is 特性來實現(xiàn):
<!-- 組件會在 `currentTabComponent` 改變時改變 --> <component v-bind:is="currentTabComponent"></component>
你會注意到,如果你選擇了一篇文章,切換到 Archive 標(biāo)簽,然后再切換回 Posts,是不會繼續(xù)展示你之前選擇的文章的。這是因為你每次切換新標(biāo)簽的時候,Vue 都創(chuàng)建了一個新的 currentTabComponent 實例。
重新創(chuàng)建動態(tài)組件的行為通常是非常有用的,但是在這個案例中,我們更希望那些標(biāo)簽的組件實例能夠被在它們第一次被創(chuàng)建的時候緩存下來。為了解決這個問題,我們可以用一個 <keep-alive> 元素將其動態(tài)組件包裹起來。
<!-- 失活的組件將會被緩存!--> <keep-alive> <component v-bind:is="currentTabComponent"></component> </keep-alive>
可以在這里查看動態(tài)組件例子。https://jsfiddle.net/chrisvfritz/Lp20op9o/
dom標(biāo)簽內(nèi)使用組件
有些 HTML 元素,諸如 <ul>、<ol>、<table> 和 <select>,對于哪些元素可以出現(xiàn)在其內(nèi)部是有嚴(yán)格限制的。而有些元素,諸如 <li>、<tr> 和 <option>,只能出現(xiàn)在其它某些特定的元素內(nèi)部。
這會導(dǎo)致我們使用這些有約束條件的元素時遇到一些問題。例如:
<table> <blog-post-row></blog-post-row> </table>
這個自定義組件 <blog-post-row> 會被作為無效的內(nèi)容提升到外部,并導(dǎo)致最終渲染結(jié)果出錯。幸好這個特殊的 is 特性給了我們一個變通的辦法:
<table> <tr is="blog-post-row"></tr> </table>
相關(guān)文章
關(guān)于vue.js中實現(xiàn)方法內(nèi)某些代碼延時執(zhí)行
今天小編就為大家分享一篇關(guān)于vue.js中實現(xiàn)方法內(nèi)某些代碼延時執(zhí)行,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11vue如何實現(xiàn)拖動圖片進行排序Vue.Draggable
這篇文章主要介紹了vue如何實現(xiàn)拖動圖片進行排序Vue.Draggable,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-04-04vue3原始值響應(yīng)方案及響應(yīng)丟失問題解讀
這篇文章主要介紹了vue3原始值響應(yīng)方案及響應(yīng)丟失問題解讀,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-04-04vue2.0使用Sortable.js實現(xiàn)的拖拽功能示例
本篇文章主要介紹了vue2.0使用Sortable.js實現(xiàn)的拖拽功能示例,具有一定的參考價值,感興趣的小伙伴們可以參考一下。2017-02-02關(guān)于Vue新搭檔TypeScript快速入門實踐
這篇文章主要介紹了關(guān)于Vue新搭檔TypeScript快速入門實踐,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-09-09vxe-table中vxe-grid(高級表格)的使用方法舉例
vxe-table是一個基于vue的表格組件,下面這篇文章主要給大家介紹了關(guān)于vxe-table中vxe-grid(高級表格)的使用方法,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-05-05