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

vue3?使用defineAsyncComponent與component標(biāo)簽實現(xiàn)動態(tài)渲染組件思路詳解

 更新時間:2023年03月02日 15:33:09   作者:小何開發(fā)  
這篇文章主要介紹了vue3?使用defineAsyncComponent與component標(biāo)簽實現(xiàn)動態(tài)渲染組件,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

內(nèi)容有些啰嗦,內(nèi)容記載了當(dāng)時遇到了bug以及解決問題的思路。

業(yè)務(wù)場景簡述:

前端做配置化組件,通過url內(nèi)的唯一標(biāo)識,請求后端sql 哪取頁面配置信息,前端通過配置信息動態(tài)渲染查詢表單,導(dǎo)出、表格,toolbar以及動態(tài)彈窗;該動態(tài)渲染組件的功能,就是渲染的toolbar內(nèi)的按鈕,類型為自定義彈窗,彈窗路徑為后端配置數(shù)據(jù),前端通過點擊該按鈕,打開指定路徑下的彈窗組件。

之前用的vue2的動態(tài)掛載組件,也沒見vue3那么麻煩,官網(wǎng)上的例子以及網(wǎng)上的所以例子都是前端知道要導(dǎo)哪些組件,然后程序進(jìn)入就直接導(dǎo)進(jìn)來了,只是寫了邏輯動態(tài)切換。我這個不一樣,需要掛載的組件是未知的。所以實現(xiàn)起來有點吃力。

一、基礎(chǔ)的動態(tài)引入組件:

簡單的動態(tài)引入的意思是,前端知道要引入哪些組件,將多個組件引入到父組件中,但不渲染它,滿足一定條件后,才去在某個位置渲染指定的組件。

<template>
	 <custom-modal ref="custom"></custom-modal>
</template>
<script>
 import {
    reactive,
    ref,
    shallowReactive,
    onActivated,
    defineAsyncComponent,
  } from 'vue';
 const customModal = defineAsyncComponent(() => import('./modal/CustomModal.vue'));
 const custom = ref();
 </script>

以上的例子就是通過vue的defineAsyncComponent實現(xiàn)掛載組件,并賦值給customModal ,模板中可以直接使用<custom-modal>作為標(biāo)簽使用,也可以將它賦值給component中的is屬性,is屬性執(zhí)向一個變量,可通過業(yè)務(wù)邏輯動態(tài),更改該變量的值,就可以實現(xiàn)多個組件進(jìn)行來回的渲染了

<template>
<component :is="componentKey" ref="custom"></component>
</template>
 import {
    reactive,
    ref,
    shallowReactive,
    onActivated,
    defineAsyncComponent,
  } from 'vue';
 const componentKey = ref(null);
 const components: any = shallowReactive({});
 const customModal = defineAsyncComponent(() => import('./modal/CustomModal.vue'));
 componentKey  = customModal

二、復(fù)雜的引入:不確定到底引入什么組件,組件的路徑由后端返回

將以上代碼 添加到項目代碼中,并不能實現(xiàn),雖然引入不報錯,但是ref一直為undefined,無法調(diào)用動態(tài)組件內(nèi)的open函數(shù)。
不斷嘗試了很多次,得出以下結(jié)論

1.起初是在按鈕的click函數(shù)內(nèi)去掛載自定義組件并調(diào)用ref函數(shù)的,ref為undefined。
嘗試多次不能實現(xiàn)功能(這里是掛載與調(diào)用最合適的位置),
2.接著又在初始化配置數(shù)據(jù)時(查詢后端sql),axios的then函數(shù)內(nèi)掛載組件,然后點擊按鈕的地方調(diào)用ref內(nèi)的函數(shù),ref依舊為null。
3. 接著在最外層,調(diào)用初始化時掛載,也就是生命周期函數(shù)體內(nèi),測試還是一樣的結(jié)果。
4. 接著發(fā)現(xiàn)帶有async函數(shù)體內(nèi)掛載組件,也無法完成。
5.單獨寫個函數(shù),不加async,函數(shù)內(nèi)掛載組件,然后再生命周期外調(diào)用該函數(shù),按鈕內(nèi)調(diào)用ref內(nèi)的方法,成功彈窗。這并不是我想要的,因為路徑不是固定的,它要等到后端sql放回結(jié)果,才能執(zhí)行。

總結(jié):上面的多次測試,得出以下結(jié)論,都不能讓動態(tài)組件ref對象有值
1、不能在組件的事件函數(shù)內(nèi)掛載,

在這里插入圖片描述

2、不能在axios的then函數(shù)體內(nèi)掛載

在這里插入圖片描述

3、不能在帶有async聲明的函數(shù)體內(nèi)掛載

在這里插入圖片描述

4、不能在vue的生命周期內(nèi)掛載

在這里插入圖片描述

5、只能在最外層掛載實現(xiàn),這時ref才是個對象。

好在天無絕人之路;腦海里有個思路:
頁面初始化時將項目里所有的全局掛載view組件扔到一個object內(nèi),使用component組件,is:對應(yīng)object內(nèi)指定的組件對象,然后通過后端的數(shù)據(jù),這時后端就不用給組件路徑了,給個組件名,我從object中找到掛載的組件然后將對象給is。
const modules = import.meta.glob('@/views/*/**.vue'); // 獲取所有項目路徑
mudules為views內(nèi)所有的vue的相對路徑,然后循環(huán)它,在循環(huán)體內(nèi)實現(xiàn)掛載,將它存入一個對象內(nèi),key為相對路徑的項目名稱(可以截取以下)。

有了上面的思路,通過反復(fù)測試和實現(xiàn),最終功能實現(xiàn)了。

<template>
<component :is="componentKey" ref="custom"></component>
</template>
<script>
 import {
    reactive,
    ref,
    shallowReactive,
    onActivated,
    defineAsyncComponent,
  } from 'vue';
	
	//聲明componentkey,用于告訴component當(dāng)前掛載什么組件,components為一個對象,存放多個不確定的自定義組件。
  const componentKey = ref(null);
  const components: any = shallowReactive({});

  // 組件掛載
  const initTableConfig = (gridId, type) => { 
   queryTableConfig({ gridId }).then(({ data }) => {
      if (type === 'main') {
        Object.assign(mainConfig, data);
        tabsKey.value = -1;
      } else {
        tabsDetail.value.push(data);
        tabsKey.value = tabsDetail.value.length - 1;
      }
      // 涉及到自定義組件的部分,這里需要提前掛載,在用到時不至于ref為null
      XEUtils.objectEach(data.action, (action, key) => {
        if (
          action.modalCfg &&
          action.modalCfg.type === 'CustomModal' &&
          action.modalCfg.src
        ) {
          components[action.actionId] = defineAsyncComponent(
            () => import(`../../../${action.modalCfg.src}`)
          );
          //注意:這里的路徑后端只能返回相對路徑,不能使用@/xxx/xxx.vue ,不能使用src/xxx/xxx.vue,只能./xxx.vue或者../../xxx/xxx.vue。由于并不確定組件在什么位置,避免容易出錯的原則,我在前端通過../../../的形式將路徑回退到src下,后端只需要從src下配置路徑即可,不用考慮那么多了。如后端src的值為src/xxx/xxx/xxx.vue 則在前端合成的路徑就為../../../src/xx/xxx/xxx.vue
          componentKey.value = components[action.actionId];
          // 為什么componentKey.vue在這里賦值,在后面點擊窗口后又賦值,這里能不能省略。
		//	答:這里省略的話,到點擊按鈕觸發(fā)時會報錯,第一次點擊會報錯,第二次點擊不會報錯,窗口正常彈出??赡苁且驗?,組件掛載時并沒有引入組件,只在使用時才引入,如果上面不提前將掛載好的組件引入進(jìn)來,后面觸發(fā)事件觸發(fā)時引入在調(diào)用ref,執(zhí)行太快,costom就會報錯,所以才會點兩次才彈窗。
        }
      });
    });
  };
 </script>

按鈕點擊觸發(fā)事件,確定彈窗要彈出什么組件

		} else if (action.modalCfg.type === 'CustomModal') {
  		// 這里的actionid和組件是對應(yīng)的,所以在按鈕觸發(fā)后,通過按鈕攜帶的actionid能取到對應(yīng)的組件。
          componentKey.value = components[action.actionId];
          custom.value.init(row);
        }

經(jīng)過以上的方式:在任何地方掛載都不會報錯,完美解決。
注意:掛載與使用ref不能在同一個方法體內(nèi),如果可以的話,頁面加載時,執(zhí)行掛載,需要調(diào)用ref時就不會報錯。

到此這篇關(guān)于vue3 使用defineAsyncComponent與component標(biāo)簽實現(xiàn)動態(tài)渲染組件的文章就介紹到這了,更多相關(guān)vue3 動態(tài)渲染組件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 搭建element-ui的Vue前端工程操作實例

    搭建element-ui的Vue前端工程操作實例

    下面小編就為大家分享一篇搭建element-ui的Vue前端工程操作實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02
  • vue實現(xiàn)動態(tài)路由的方法及路由原理解析

    vue實現(xiàn)動態(tài)路由的方法及路由原理解析

    這篇文章主要介紹了路由原理及vue實現(xiàn)動態(tài)路由,Vue Router 提供了豐富的 API,可以輕松地實現(xiàn)路由功能,并支持路由參數(shù)、查詢參數(shù)、命名路由、嵌套路由等功能,可以滿足不同應(yīng)用程序的需求,需要的朋友可以參考下
    2023-06-06
  • vue實現(xiàn)登錄界面

    vue實現(xiàn)登錄界面

    這篇文章主要為大家詳細(xì)介紹了vue實現(xiàn)登錄界面,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • Vue樹表格分頁的實現(xiàn)方法詳解

    Vue樹表格分頁的實現(xiàn)方法詳解

    這篇文章主要介紹了Vue樹表格分頁的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-10-10
  • Vue中使用Canvas實現(xiàn)繪制二維碼

    Vue中使用Canvas實現(xiàn)繪制二維碼

    這篇文章主要為大家詳細(xì)介紹了如何在Vue中使用Canvas實現(xiàn)繪制二維碼,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2007-02-02
  • Vue子組件與父組件詳細(xì)解析

    Vue子組件與父組件詳細(xì)解析

    這篇文章主要介紹的是Vue子組件與父組件,什么是父組件,什么是子組件很多時候面對這個問題我們都會有所混淆,下面文章我們就來詳細(xì)介紹,需要的朋友可以參考一下
    2021-10-10
  • vue+springboot實現(xiàn)登錄功能

    vue+springboot實現(xiàn)登錄功能

    這篇文章主要為大家詳細(xì)介紹了vue+springboot實現(xiàn)登錄功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • vue3封裝輪播圖組件的方法

    vue3封裝輪播圖組件的方法

    這篇文章主要為大家詳細(xì)介紹了vue3封裝輪播圖組件的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • Vue設(shè)置別名聯(lián)想路徑即@/生效的方法

    Vue設(shè)置別名聯(lián)想路徑即@/生效的方法

    這篇文章主要給大家介紹了Vue設(shè)置別名聯(lián)想路徑即@/生效的方法,文中有詳細(xì)的代碼示例和圖文講解,具有一定的參考價值,需要的朋友可以參考下
    2023-11-11
  • vue中組件的name屬性含義和用法示例

    vue中組件的name屬性含義和用法示例

    組件是有name屬性的,匹配的就是組件的name,下面這篇文章主要給大家介紹了關(guān)于vue中組件的name屬性含義和用法的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-12-12

最新評論