Vue.js的復用組件開發(fā)流程完整記錄
前言
從維護視圖到維護數(shù)據(jù),Vue.js 讓我們快速地開發(fā)應用。但隨著業(yè)務代碼日益龐大,組件也越來越多,組件邏輯耦合嚴重,使代碼維護變得十分困難。
接下來我們會詳細分析下如何完成由多個組件組成一個復用組件的開發(fā)流程。
下面先看看我們的需求
列表組件quiList.vue
本節(jié)我們主要要完成這樣一個列表功能,每一行的列表是一個組件,列表內(nèi)可能出現(xiàn)按鈕組件或者箭頭組件,點擊按鈕組件可以自定義事件,同時可以根據(jù)不同的參數(shù)來決定當前列表是帶按鈕的列表or帶箭頭的列表。

首先看看quiList.vue
//quiList.vue
<template>
<div class="qui-list">
<span class="list-tips">{{tipsText}}</span>
<qui-btn v-on:btnClickEvent="btnClickEvent" :msg=msg class="small"></qui-btn>
</div>
</template>
<script>
import quiButton from '../components/quiButton.vue'
export default{
props:{
msg: {
default: '下載'
},
tipsText: {
default: '默認的文案'
}
},
components: {
'qui-btn': quiButton
},
methods:{
btnClickEvent:function(){
alert('按鈕點擊事件')
}
}
}
</script>
上面的知識點基本上就是我們之前學過的,只不過記住quiList本身是一個組件,而在這個組件里面,我們又引入了按鈕組件quiButton,也就是組件內(nèi)引用組件,實際上就是組件的嵌套,注意到這里:msg=msg的使用,這里冒號表示綁定的是一個變量msg,然后這個屬性通過props暴露出去(本身在按鈕中就暴露了msg給列表組件使用),借用下面一張圖理解下:

至于點擊事件,也是我們之前學習過的事件的綁定?,F(xiàn)在引入一個新問題,是否有一個參數(shù),可以決定列表組件的右側(cè)是放置按鈕組件呢?還是箭頭組件。
動態(tài)組件
Vue中提供了一些特定關(guān)鍵字:is和特定的結(jié)構(gòu)<component>來生成動態(tài)組件,讓我們修改下script里面的內(nèi)容先:
<script>
import quiButton from '../components/quiButton.vue'
import quiArrow from '../components/quiArrow.vue'
export default{
props:{
msg: {
default: '下載'
},
tipsText: {
default: '默認的文案'
},
currentView:{
default: 'qui-btn'
}
},
components: {
'qui-btn': quiButton,
'qui-arrow': quiArrow
},
methods: {
clickEvent: function () {
}
}
}
</script>
首先我們先Import多一個箭頭組件,在components中添加一個自定義標簽‘qui-arrow',注意到我們多了一個currentView的自定義屬性,默認值是qui-btn,現(xiàn)在再看看template標簽里面寫什么:
<template>
<div class="qui-list">
<span class="list-tips">{{tipsText}}</span>
<component :is="currentView" v-on:btnClickEvent="clickEvent" :msg=msg class="small" keep-alive></component>
</div>
</template>
我們把qui-btn標簽去掉了,取而代之的是一個component標簽,這是Vue自帶的一個標簽,可以把它當作一個容器,這個容器可以用來裝按鈕,也可以用來裝箭頭。決定這個容器裝的是哪個組件的關(guān)鍵代碼在于:is="currentView",當currentView的值為qui-btn的時候,這個容器就是按鈕組件,當它是qui-arrow的時候,就是箭頭組件。而我們剛才給這個變量定義的默認值是qui-btn。
keep-alive關(guān)鍵字保持這個組件在內(nèi)存中是常駐的,由于動態(tài)組件可能需要動態(tài)切換,這樣保持組件活躍可以減少組件變化時候的內(nèi)存消耗。
可以看到我們的component上還保留著按鈕的點擊事件和msg信息,這些沒有關(guān)系,只要箭頭組件中不出現(xiàn)同樣的變量就不會發(fā)生沖突。
<qui-list tipsText="自定義文案,默認右邊是按鈕" msg="彈層"></qui-list> <qui-list v-on:btnClickEvent="test"></qui-list> <qui-list ref="child1" tipsText="最右邊是箭頭" currentView="qui-arrow"></qui-list>
使用列表組件的時候,只需要給暴露出來的currentView指定一個值,就可以決定右側(cè)是按鈕還是箭頭了。注意最后一個qui-list上有一個ref的屬性,這個屬性代表組件集合,當頁面中有很多組件的時候,可以通過幾種方法來獲取對應的某個組件的信息:
console.log(this.$children[0].msg);//通過數(shù)組獲取 console.log(this.$refs.child1.msg);//通過對象集合獲取
其實關(guān)于動態(tài)組件,不一定要用:is+component來實現(xiàn),在Vue中有一個指令叫做v-if / v-else / v-else-if,統(tǒng)稱判斷指令,配合展示指令v-show,可以根據(jù)指定的值來決定對應的組件是否應該展示,另外這種做法我不展示了,就當做一個作業(yè)吧,有興趣的還是建議實戰(zhàn)一下,畢竟我們也只是教大家入門學習,后面還是希望大家能夠自己去擴展學習。
生命周期
這里簡單講一下什么是組件的生命周期,上面我們通過refs來獲取組件對象的信息,那么在什么時候或者說哪個時機點去做這件事呢,組件從引用到調(diào)用到銷毀(比較少操作)有以下幾個關(guān)鍵回調(diào)函數(shù):
<script>
export default {
components: {
'qui-list': quiList
},
beforeCreate:function(){},//組件實例化之前
created:function(){},//組件實例化了
beforeMount:function(){},//組件寫入dom結(jié)構(gòu)之前
mounted:function(){//組件寫入dom結(jié)構(gòu)了
console.log(this.$children);
console.log(this.$refs);
},
beforeUpdate:function(){},//組件更新前
updated:function(){},//組件更新比如修改了文案
beforeDestroy:function(){},//組件銷毀之前
destroyed:function(){}//組件已經(jīng)銷毀
}
</script>
所以要想使用refs的內(nèi)容,就需要在組件寫入dom之后才能開始調(diào)用哦!
我還需要學什么
目前為止,我們?nèi)恼乱呀?jīng)學了大部分的關(guān)于組件和路由的知識,當然這并不是Vue的全部,只是相對于其他的知識點,這些可以算是一個墊腳石,看懂了這些,對后面其他API的應用,幫助很大。下面我列舉一些其他的,后續(xù)大家可以去官網(wǎng)查看資料的一些關(guān)鍵點,其實都不難,只要有一些小小的項目demo實踐,你會發(fā)現(xiàn)Vue也不過如此。
過渡
過渡其實就是CSS3動畫,transition這些,只是寫CSS3變成好像在寫JS一樣,有點類似于greenSock的一些思想。
指令
目前為止我們學習了一些常用指令,像v-on,v-bind,v-for,還有幾個常用的像剛才提到的判斷指令和v-show指令,還有v-model指令(主要用于input等表單組件)。當知道指令作用的時候,學習起來其實并不難。
Render
渲染這個方法是我覺得應該用心去學習的,它可以方便我們寫出更好的面向?qū)ο蟮慕M件,而學習它的成本在于這個接口更接近于原生JS代碼的使用。如果有需要,后續(xù)也可以寫一篇關(guān)于Render的文章。
總結(jié)
三篇系列文暫時在這里告一段落,有些童靴可能到這里還是覺得沒有學會Vue,對不起,可能是我的標題太夸張了,也可能因為我的例子還不夠清晰,文筆也還不好理解。不過沒關(guān)系,回顧我們的學習歷程,你可以按照這個知識點的學習過程,去找更多的文章,畢竟“熟讀唐詩三百首,不會作詩也會吟”嘛。當然,學習過程中我們自己更多的練習和嘗試才能鍛煉鞏固知識。至于淺入之后是淺出還是深出,還是要靠大家自己去定義了!
文末附上所有相關(guān)代碼和官方文檔地址~~~
http://cn.vuejs.org/v2/guide/
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
Vuejs 組件——props數(shù)據(jù)傳遞的實例代碼
本篇文章主要介紹了Vuejs 組件——props數(shù)據(jù)傳遞的實例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下。2017-03-03
Vue API中setup ref reactive函數(shù)使用教程
setup是用來寫組合式api,內(nèi)部的數(shù)據(jù)和方法需要通過return之后,模板才能使用。在之前vue2中,data返回的數(shù)據(jù),可以直接進行雙向綁定使用,如果我們把setup中數(shù)據(jù)類型直接雙向綁定,發(fā)現(xiàn)變量并不能實時響應。接下來就詳細看看它們的使用2022-12-12
關(guān)于vue v-for 循環(huán)問題(一行顯示四個,每一行的最右邊那個計算屬性)
這篇文章主要介紹了關(guān)于vue v-for 循環(huán)問題(一行顯示四個,每一行的最右邊那個計算屬性),需要的朋友可以參考下2018-09-09

