Vue3的setup在el-tab中動態(tài)加載組件的方法
公司某項目需求在頁面顯示的組件是根據(jù)角色變化而變化的,在這個項目中我使用了elementplus的el-tabs來動態(tài)的顯示這些組件,如下圖所示
<template>
<component style="margin-top:15px" v-for="item in pageList" :is="item.module_id"/>
</template>

數(shù)據(jù)內(nèi)容大概是這樣的

在未使用setup語法糖時候我要引入組件只需要在components中定義組件就好了,如下圖

然后就可以快樂得在component組件的:is中遍歷進(jìn)組件的名稱就好了;但是在使用了setup語法糖之后,沒有了components選項,我突然就有點無從下手,在vue3官網(wǎng)中我看到了setup掛載組件的用法

那就照著官網(wǎng)照貓畫虎吧,于是就寫下了如下代碼
<div>
<el-tabs type="border-card">
<el-tab-pane v-for="page in pageList" :label="page.module_desc">
<componet :is="page.module_id"></component>
</el-tabs>
</div>


然后發(fā)現(xiàn)不對勁,啥也不顯示,進(jìn)devtools一看,這東西怎么沒掛上啊

啥也沒有!
沒辦法,再仔細(xì)看看官網(wǎng)文檔吧

官網(wǎng)中明確說明組件是通過變量引用而不是基于字符串組件名注冊的,然而我在數(shù)據(jù)庫中取出來的組件名必然是字符串,這可咋整,只能用eval了唄
pageList.value=
(await GetMainpageList(store.state.userid)).data
.mpa(x=>{
return {module_desc:x.module_desc,module_id:eval(x.module_id)}
})
但是還是不行,瀏覽器報錯

難道import定義組件在這里面不行?那就試試defineAsyncComponent試試

OK,能看見了

查看打印結(jié)果,moudle_id內(nèi)容也變成組件了

問題解決
到此這篇關(guān)于Vue3的setup在el-tab中動態(tài)加載組件的文章就介紹到這了,更多相關(guān)vue3 setup動態(tài)加載組件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
elementPlus?的el-select在提示框關(guān)閉時自動彈出的問題解決
這篇文章主要介紹了elementPlus?的el-select在提示框關(guān)閉時自動彈出閉時自動彈出的問題,主要問題就是因為filterable屬性,根本解決方案是選中的時候讓他失去焦點?el-select有一個visible-change事件,下拉框出現(xiàn)/隱藏時觸發(fā),感興趣的朋友跟隨小編一起看看吧2024-01-01
Vue Element前端應(yīng)用開發(fā)之開發(fā)環(huán)境的準(zhǔn)備工作
這篇文章主要介紹了Vue Element前端應(yīng)用開發(fā)之開發(fā)環(huán)境的準(zhǔn)備工作,對Vue感興趣的同學(xué),可以來學(xué)習(xí)一下2021-05-05
vue使用多級彈窗(Dialog)出現(xiàn)蒙版遮罩問題及解決
這篇文章主要介紹了vue使用多級彈窗(Dialog)出現(xiàn)蒙版遮罩問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-02-02

