使用Vue3創(chuàng)建多布局系統(tǒng)的三種方法
1. 將布局導(dǎo)入為常規(guī)組件以創(chuàng)建布局系統(tǒng)
這是創(chuàng)建布局系統(tǒng)的最簡單方法,但其靈活性較差。為了簡化解釋,我們就用我上面的例子來說明吧。
我們有5頁:
- 首頁(將有特定的布局)
- 關(guān)于和聯(lián)系(將具有營銷布局)
- Inside1和Inside2(將擁有應(yīng)用程序布局)
我們將創(chuàng)建一個(gè)名為“layouts”的文件夾,在其中我們將創(chuàng)建包含插槽的三個(gè)布局組件。
然后,你只需像這樣在每個(gè)頁面組件中導(dǎo)入你需要的布局:
這種方法存在兩個(gè)主要問題:
- 需要在每個(gè)頁面中導(dǎo)入布局,當(dāng)然,你可以將這些組件設(shè)為全局的,但你仍然需要每次手動(dòng)包裝你的內(nèi)容。
- 每次路由更改時(shí),布局都將被卸載并銷毀,即使下一個(gè)路由使用相同的布局。
這會(huì)對(duì)性能產(chǎn)生一點(diǎn)影響,但真正的問題是,即使它們使用相同的布局,你也無法在一個(gè)路由到另一個(gè)路由之間保持狀態(tài)。
2. 利用Vue Router,路由的元屬性,以及動(dòng)態(tài)組件來創(chuàng)建布局系統(tǒng)
為了避免在每個(gè)頁面中導(dǎo)入布局,我們可以選擇在路由器中一次性導(dǎo)入,然后為每個(gè)路由分配其關(guān)聯(lián)的布局。
如此處所示,我們直接將每個(gè)布局組件對(duì)象與每個(gè)路由的元數(shù)據(jù)屬性關(guān)聯(lián)。我們只導(dǎo)入了一次所有的布局。
為了避免布局被卸載和破壞,我們將把布局放在頁面之上,而不是放在頁面內(nèi)部。
為了將布局置于頁面之上,我們?cè)贏pp.vue組件中創(chuàng)建了一個(gè)動(dòng)態(tài)組件。
在模板中,我們可以通過$route訪問當(dāng)前的路由,并且在每個(gè)路由上,我們都可以訪問其元屬性,這意味著我們可以訪問之前設(shè)置的布局組件對(duì)象。
如果路由在元對(duì)象上沒有布局屬性,我們將回退到使用DIV標(biāo)簽的字符串。
我們只需導(dǎo)入一次布局,無需在每個(gè)頁面中導(dǎo)入或包裝布局,現(xiàn)在,我們不會(huì)有性能問題,而且在從具有相同布局的兩個(gè)路由導(dǎo)航時(shí),我們可以保持狀態(tài)。
所以,我的主頁組件現(xiàn)在看起來像這樣:
無需再包裝任何東西;所有的事情都在App.vue中處理,圍繞的 <router-view>
每當(dāng)路由改變時(shí)的每個(gè)頁面。
這種方法在大多數(shù)使用場(chǎng)景中都有效,但它存在一個(gè)問題
布局只有在 route 改變時(shí)才會(huì)變化。
如果你需要在不改變路由的情況下動(dòng)態(tài)改變布局,那么這種方法將不起作用。只有在少數(shù)情況下,你可能會(huì)想要?jiǎng)討B(tài)地改變布局,但這是有可能發(fā)生的。
例如:
- 在一段時(shí)間后顯示一個(gè)鎖定的頁面
- 為了顯示一個(gè)離線頁面
- 為了顯示錯(cuò)誤頁面
那些示例可以通過全屏 modal 系統(tǒng)來實(shí)現(xiàn),但是 modal 很容易通過控制臺(tái)從DOM中刪除。
3. 使用 ShallowRef,Provide,Inject 以及 Vue Router 的 afterEach鉤子來創(chuàng)建布局系統(tǒng)
為了能夠在任何地方更改布局,而不僅僅是在路由更改時(shí),我們需要在整個(gè)應(yīng)用程序中共享布局的狀態(tài)。
我們可以使用 Vuex 或 Pina 來實(shí)現(xiàn)這個(gè)功能,但在這里我們還是保持簡單吧。
我們將使用Vue的原生響應(yīng)性系統(tǒng),配合組合api。
以下是步驟:
- 在App.vue中,我們將創(chuàng)建一個(gè)布局常量,該常量包含一個(gè)shallowRef以保存當(dāng)前的布局組件。
- 在一個(gè)單獨(dú)的文件中,我們將創(chuàng)建一個(gè)包含每個(gè)布局名稱及其組件的鍵/值對(duì)的對(duì)象
- 在App.vue或其他地方,我們將使用路由器的afterEach鉤子來監(jiān)聽每次路由變化,以動(dòng)態(tài)地改變當(dāng)前的布局。
- 在App.vue中,我們將向其后代提供布局常量,以便App.vue的樹中的任何組件都可以注入布局常量來改變其值。
- 在路由中,我們將把元數(shù)據(jù)上的每個(gè)布局屬性更改為僅包含要選擇的布局名稱的字符串。
那么,這里是第二步,一個(gè)包含所有布局并作為對(duì)象展示的文件:
現(xiàn)在我們也可以將路由中的元數(shù)據(jù)僅更改為字符串,因?yàn)樗鼈儗⒂成涞缴鲜鰧?duì)象:
現(xiàn)在讓我們把所有這些結(jié)合在一起:
我們?yōu)槭裁词褂?shallowRef
而不是 ref
?
由于我們正在存儲(chǔ)一個(gè)組件,這是一個(gè)包含許多嵌套值的復(fù)雜對(duì)象,使用 ref
會(huì)導(dǎo)致性能問題。
這也是不必要的,因?yàn)槲覀冎恍枰勒麄€(gè)組件何時(shí)發(fā)生了變化,而不是嵌套值何時(shí)發(fā)生了變化。
那么,我們?nèi)绾卧诼酚善髦鈩?dòng)態(tài)改變布局呢?嗯,隨處都可以!
以下是一個(gè)例子,展示了 Home 布局可以通過一鍵點(diǎn)擊進(jìn)行更改。
如你所見,我們現(xiàn)在可以注入并訪問布局的狀態(tài),并將其更改為我們想要的任何組件。多虧了響應(yīng)性,它將動(dòng)態(tài)地改變App.vue中的組件。
如前所述,對(duì)于共享狀態(tài),我們可以使用Vuex或Pinia來做同樣的事情,但對(duì)于大多數(shù)情況來說,這已經(jīng)足夠了。
以上就是使用Vue3創(chuàng)建多布局系統(tǒng)的三種方法的詳細(xì)內(nèi)容,更多關(guān)于Vue3創(chuàng)建多布局系統(tǒng)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- vue3.0+element Plus實(shí)現(xiàn)頁面布局側(cè)邊欄菜單路由跳轉(zhuǎn)功能
- vue3容器布局和導(dǎo)航路由實(shí)現(xiàn)示例
- Vue3.0利用vue-grid-layout插件實(shí)現(xiàn)拖拽布局
- Vue3(三)網(wǎng)站首頁布局開發(fā)
- Vue3中使用vuedraggable拖拽實(shí)戰(zhàn)教程
- vue3使用vuedraggable實(shí)現(xiàn)拖拽功能
- vue3.x 使用jsplumb實(shí)現(xiàn)拖拽連線
- vue3 座位選座矩陣布局的實(shí)現(xiàn)方法(可點(diǎn)擊選中拖拽調(diào)換位置)
相關(guān)文章
Vue.directive 實(shí)現(xiàn)元素scroll邏輯復(fù)用
這篇文章主要介紹了Vue.directive 實(shí)現(xiàn)元素scroll邏輯復(fù)用功能,文中給大家提到元素實(shí)現(xiàn)滾動(dòng)的條件有兩個(gè),具體內(nèi)容詳情大家參考下本文2019-11-11Vue2+ElementUI利用計(jì)算屬性實(shí)現(xiàn)搜索框功能
這篇文章主要為大家詳細(xì)介紹了Vue2和ElementUI如何利用計(jì)算屬性實(shí)現(xiàn)搜索框功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2024-11-11Vue實(shí)現(xiàn)計(jì)算器計(jì)算效果
這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)計(jì)算器計(jì)算效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-08-08vue調(diào)取電腦攝像頭實(shí)現(xiàn)拍照功能
這篇文章主要為大家詳細(xì)介紹了vue調(diào)取電腦攝像頭實(shí)現(xiàn)拍照功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09axios+Vue實(shí)現(xiàn)上傳文件顯示進(jìn)度功能
這篇文章主要介紹了axios+Vue上傳文件顯示進(jìn)度效果,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-04-04vue項(xiàng)目登錄成功后退出時(shí)清空sessionId和userId的問題
這篇文章主要介紹了vue項(xiàng)目登錄成功后退出時(shí)清空sessionId和userId的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12深入理解Vue響應(yīng)式原理及其實(shí)現(xiàn)方式
Vue的響應(yīng)式原理是Vue最核心的特性之一,也是Vue能夠?yàn)殚_發(fā)者提供高效便捷的開發(fā)體驗(yàn)的重要原因之一,這篇文章主要介紹了響應(yīng)式的原理及其實(shí)現(xiàn)方式,需要詳細(xì)了解可以參考下文2023-05-05