利用Vue3實(shí)現(xiàn)拖拽定制化首頁功能
前期準(zhǔn)備
- Vue3
- Ts
- VueDragable (4版本以上)
- 期望 拖拽組件 組件可以按需加載導(dǎo)入
開始
首先呢,我們先看下VueDragable的文檔效果

文檔的效果是這種基于列表的一個(gè)拖拽排序,那么回歸到我們期望我們是想通過動(dòng)態(tài)引入組件來進(jìn)行拖拽排序,那么在完成拖拽定制化之前,首先要講的是動(dòng)態(tài)組件,在使用Vue2時(shí)候相信我們不陌生我們可以通過Component is來動(dòng)態(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的值就是我們?cè)赾omponents中注冊(cè)的組件,這樣就能完成動(dòng)態(tài)組件的注入,那么在Vue3中呢?尤其是在setup語法糖使用時(shí)候我們這樣做就會(huì)導(dǎo)致無法識(shí)別組件,這是因?yàn)閟etup語法糖中我們可以直接引入組件后使用,并不需要通過在components中注冊(cè)(默認(rèn)幫我們完成了),那么我們真實(shí)的業(yè)務(wù)場(chǎng)景其實(shí)后臺(tái)返給我們的數(shù)據(jù)是這個(gè)格式的:

因此,我們的動(dòng)態(tài)組件也需要做調(diào)整:
<div class="component-box" v-for="element in xxx"> <component :is="element.name" :key="element.name"/> </div>
這時(shí)候我們的is綁定就并非一個(gè)組件的實(shí)例了,其實(shí)是一個(gè)字符串,如此一來,就會(huì)產(chǎn)生錯(cuò)誤并且導(dǎo)致頁面無法正常加載我們的組件,那么該怎么辦呢?大傻在網(wǎng)上做了調(diào)研,有三種方法:
方法一
通過Vue3的defineAsyncComponent方法去完成動(dòng)態(tài)加載組件,使其成為一個(gè)實(shí)例對(duì)象。
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'))
)這樣我們?cè)谌≈禃r(shí)候可以通過get方法傳入具體字符串拿到對(duì)應(yīng)的組件
方法二
這個(gè)則是通過shallowRef 或者 markRaw 來進(jìn)行代理,shallowRef是淺層代理,只去代理一層,而markRaw則是標(biāo)記該屬性永遠(yuǎn)不為響應(yīng)式
import { shallowRef, ref } from 'vue'
import test1 from './test1.vue'
import test2 from './test2.vue'
//這里用ref的話,vue給出警告Vue接收到一個(gè)組件,該組件被制成響應(yīng)對(duì)象。這可能會(huì)導(dǎo)致不必要的性能開銷,應(yīng)該通過將組件標(biāo)記為“markRaw”或使用“shallowRef”而不是“ref”來避免。
// 如果使用 markRaw 那么currentComp將不永遠(yuǎn)不會(huì)再成為響應(yīng)式對(duì)象。 所以得使用 shallowRef
let currentComp = shallowRef(test1)
currentComp.value
// 切換組件
const changeComp = () => {
if(currentComp.value == test1) {
currentComp.value = test2
}else {
currentComp.value = test1
}
}這種方法可行,但是不能傳入字符串進(jìn)行動(dòng)態(tài)引入
方案三
雙script標(biāo)簽完美解決
<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: '測(cè)試1',
id: '1'
},
{
name: 'Test2',
title: '測(cè)試2',
id: '2'
}
])
</script>這樣我們可以直接去拿到后臺(tái)數(shù)據(jù)進(jìn)行處理。
最終實(shí)現(xiàn)結(jié)果

大傻最終呢,也是通過不斷地爬坑去實(shí)現(xiàn)了這個(gè)拖拽效果,目前完成了橫縱方向兩種布局,待拓展的也就是,可定制寬高等等這些內(nèi)容。有興趣可以留言,大家一起交流。感興趣的可以克隆下來試一試
總結(jié)
到此這篇關(guān)于利用Vue3實(shí)現(xiàn)拖拽定制化首頁功能的文章就介紹到這了,更多相關(guān)Vue3拖拽定制化首頁內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue中的計(jì)算屬性的使用和vue實(shí)例的方法示例
本篇文章主要介紹了vue計(jì)算屬性的使用和vue實(shí)例的方法示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-12-12
解決node-sass安裝報(bào)錯(cuò)無python等情況
在國(guó)內(nèi)安裝node-sass常因無法穩(wěn)定連接GitHub而失敗,解決方法包括手動(dòng)下載對(duì)應(yīng)的binding.node文件并放入緩存目錄,操作步驟詳細(xì),適合非Python用戶,無需額外環(huán)境配置2024-10-10
vue2.0 移動(dòng)端實(shí)現(xiàn)下拉刷新和上拉加載更多的示例
本篇文章主要介紹vue2.0 移動(dòng)端實(shí)現(xiàn)下拉刷新和上拉加載更多的示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-04-04
defineProps宏函數(shù)不需要從vue中import導(dǎo)入的原因解析
這篇文章主要介紹了defineProps宏函數(shù)不需要從vue中import導(dǎo)入的原因解析,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2024-07-07
Vue偵測(cè)相關(guān)api的實(shí)現(xiàn)方法
這篇文章主要介紹了Vue偵測(cè)相關(guān)api,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05
Vue設(shè)置提示和警告彈出框?qū)崙?zhàn)案例
頁面中會(huì)有很多時(shí)候需要彈窗提示,下面這篇文章主要給大家介紹了關(guān)于Vue設(shè)置提示和警告彈出框的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-02-02
Vue常見組件間通信方案及典型應(yīng)用場(chǎng)景詳解
這篇文章主要為大家介紹了Vue常見組件間通信方案及典型應(yīng)用場(chǎng)景詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09
Vue引用vee-validate插件表單驗(yàn)證問題(cdn方式引用)
這篇文章主要介紹了Vue引用vee-validate插件表單驗(yàn)證問題(cdn方式引用),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12

