亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

利用Vue3實現(xiàn)拖拽定制化首頁功能

 更新時間:2022年05月07日 11:04:17   作者:王大傻  
vue3正式版已經發(fā)布大半年了,咱也得緊跟時代潮流,vue3帶來的很多改變,下面這篇文章主要給大家介紹了關于利用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生命周期全面系統(tǒng)詳解

    VUE生命周期全面系統(tǒng)詳解

    Vue的生命周期就是vue實例從創(chuàng)建到銷毀的全過程,也就是new?Vue()?開始就是vue生命周期的開始。Vue?實例有?個完整的?命周期,也就是從開始創(chuàng)建、初始化數(shù)據(jù)、編譯模版、掛載Dom?->?渲染、更新?->?渲染、卸載?等?系列過程,稱這是Vue的?命周期
    2022-07-07
  • vue3使用socket.io的踩坑實戰(zhàn)記錄

    vue3使用socket.io的踩坑實戰(zhàn)記錄

    Socket.io將Websocket和輪詢機制以及其它的實時通信方式封裝成了通用的接口,并且在服務端實現(xiàn)了這些實時機制的相應代碼,下面這篇文章主要給大家介紹了關于vue3使用socket.io踩坑的相關資料,需要的朋友可以參考下
    2023-03-03
  • Vue自定義指令獲取不到參數(shù)的原因及解決

    Vue自定義指令獲取不到參數(shù)的原因及解決

    這篇文章主要介紹了Vue自定義指令獲取不到參數(shù)的原因及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • vue中watch的實際開發(fā)學習筆記

    vue中watch的實際開發(fā)學習筆記

    watch是Vue實例的一個屬性是用來響應數(shù)據(jù)的變化,需要在數(shù)據(jù)變化時執(zhí)行異步或開銷較大的操作時,這個方式是最有用的,下面這篇文章主要給大家介紹了關于vue中watch的實際開發(fā)筆記,需要的朋友可以參考下
    2022-11-11
  • Vue解決element-ui消息提示$message重疊問題

    Vue解決element-ui消息提示$message重疊問題

    這篇文章主要為大家介紹了Vue解決element-ui消息提示$message重疊問題,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-08-08
  • 對vue 鍵盤回車事件的實例講解

    對vue 鍵盤回車事件的實例講解

    今天小編就為大家分享一篇對vue 鍵盤回車事件的實例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • Vue事件符.capture的含義及用法說明

    Vue事件符.capture的含義及用法說明

    這篇文章主要介紹了Vue事件符.capture的含義及用法說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • vue項目從node8.x升級到12.x后的問題解決

    vue項目從node8.x升級到12.x后的問題解決

    這篇文章主要介紹了vue項目從node8.x升級到12.x后的問題解決,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-10-10
  • vue2+springsecurity權限系統(tǒng)的實現(xiàn)

    vue2+springsecurity權限系統(tǒng)的實現(xiàn)

    本文主要介紹了vue2+springsecurity權限系統(tǒng)的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-05-05
  • vue中如何通過iframe方式加載本地的vue頁面

    vue中如何通過iframe方式加載本地的vue頁面

    這篇文章主要介紹了vue中如何通過iframe方式加載本地的vue頁面,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09

最新評論