利用Vue3實現(xiàn)拖拽定制化首頁功能
前期準備
- Vue3
- Ts
- VueDragable (4版本以上)
- 期望 拖拽組件 組件可以按需加載導入
開始
首先呢,我們先看下VueDragable的文檔效果
文檔的效果是這種基于列表的一個拖拽排序,那么回歸到我們期望我們是想通過動態(tài)引入組件來進行拖拽排序,那么在完成拖拽定制化之前,首先要講的是動態(tài)組件,在使用Vue2時候相信我們不陌生我們可以通過Component is來動態(tài)引入,如:
<template> <div class="component-box"> <component :is="xxx""/> </div> </template> <script> import xxx from 'xxx.vue' export default{ data(){ return{ } }, components:{ xxx } } </script>
其中is的值就是我們在components中注冊的組件,這樣就能完成動態(tài)組件的注入,那么在Vue3中呢?尤其是在setup語法糖使用時候我們這樣做就會導致無法識別組件,這是因為setup語法糖中我們可以直接引入組件后使用,并不需要通過在components中注冊(默認幫我們完成了),那么我們真實的業(yè)務場景其實后臺返給我們的數(shù)據(jù)是這個格式的:
因此,我們的動態(tài)組件也需要做調整:
<div class="component-box" v-for="element in xxx"> <component :is="element.name" :key="element.name"/> </div>
這時候我們的is綁定就并非一個組件的實例了,其實是一個字符串,如此一來,就會產生錯誤并且導致頁面無法正常加載我們的組件,那么該怎么辦呢?大傻在網上做了調研,有三種方法:
方法一
通過Vue3的defineAsyncComponent方法去完成動態(tài)加載組件,使其成為一個實例對象。
import { defineAsyncComponent, ref } from 'vue' // 需要加載的組件集合 const components = ref(new Map<string, any>()) components.value.set( 'test1', defineAsyncComponent(() => import('./test1.vue')) ) components.value.set( 'test2', defineAsyncComponent(() => import('./test2.vue')) )
這樣我們在取值時候可以通過get方法傳入具體字符串拿到對應的組件
方法二
這個則是通過shallowRef 或者 markRaw 來進行代理,shallowRef是淺層代理,只去代理一層,而markRaw則是標記該屬性永遠不為響應式
import { shallowRef, ref } from 'vue' import test1 from './test1.vue' import test2 from './test2.vue' //這里用ref的話,vue給出警告Vue接收到一個組件,該組件被制成響應對象。這可能會導致不必要的性能開銷,應該通過將組件標記為“markRaw”或使用“shallowRef”而不是“ref”來避免。 // 如果使用 markRaw 那么currentComp將不永遠不會再成為響應式對象。 所以得使用 shallowRef let currentComp = shallowRef(test1) currentComp.value // 切換組件 const changeComp = () => { if(currentComp.value == test1) { currentComp.value = test2 }else { currentComp.value = test1 } }
這種方法可行,但是不能傳入字符串進行動態(tài)引入
方案三
雙script標簽完美解決
<script lang="ts"> import { Test1, Test2, } from './components/DragComponents' export default { components: { Test1, Test2, } } </script> <script setup lang="ts"> const componentList = reactive([ { name: 'Test1', title: '測試1', id: '1' }, { name: 'Test2', title: '測試2', id: '2' } ]) </script>
這樣我們可以直接去拿到后臺數(shù)據(jù)進行處理。
最終實現(xiàn)結果
大傻最終呢,也是通過不斷地爬坑去實現(xiàn)了這個拖拽效果,目前完成了橫縱方向兩種布局,待拓展的也就是,可定制寬高等等這些內容。有興趣可以留言,大家一起交流。感興趣的可以克隆下來試一試
總結
到此這篇關于利用Vue3實現(xiàn)拖拽定制化首頁功能的文章就介紹到這了,更多相關Vue3拖拽定制化首頁內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Vue解決element-ui消息提示$message重疊問題
這篇文章主要為大家介紹了Vue解決element-ui消息提示$message重疊問題,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-08-08vue2+springsecurity權限系統(tǒng)的實現(xiàn)
本文主要介紹了vue2+springsecurity權限系統(tǒng)的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-05-05