欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue3動(dòng)態(tài)組件<component>渲染失效原因分析

 更新時(shí)間:2024年11月01日 11:17:33   作者:小達(dá)不劉  
在vue2中使用正常,但是遷移到Vue3中,發(fā)現(xiàn)組件無法渲染, 本文給大家分別展示Vue2和Vue3的代碼,組件能正常在Vue2中渲染,在Vue確沒有渲染出來,并通過代碼示例給出了解決方法,需要的朋友可以參考下

在Vue2中偽代碼如下:

<template>
    <component
        :is="currentActiveTab.component"
        ref="componentRef"
        :key="currentActiveTab.key"
        :current-active-tab="currentActiveTab"
        v-bind="currentActiveTab"
    />
</template>
<script>
import A from './components/A'
import B from './components/B'
import C from './components/C'
export default {
  components: {
    A,
    B,
    C
  },
  data() {
    return {
      tabList: [
        {
          name: '概覽視圖',
          key: 'all',
          component: 'OverviewGraph'
        }
      ],
      activetab: 'all',
    }
  },
  computed: {
    currentActiveTab() {
      return this.tabList.find((v) => v.key === this.activetab)
    }
  }
}
</script>

遷移到Vue3中代碼如下:

<template>
    <component
        :is="currentActiveTab.component"
        ref="componentRef"
        :key="currentActiveTab.key"
        :current-active-tab="currentActiveTab"
        v-bind="currentActiveTab"
    />
</template>
<script setup lang="ts">
import { ref, onMounted, computed, nextTick } from 'vue'
import A from './components/A.vue'
import B from './components/B.vue'
import C from './components/C.vue'

const tabList = ref([
    {
      name: '概覽視圖',
      key: 'all',
      component: 'OverviewGraph'
    }
  ])
  const activetab = ref('all')
  
  const currentActiveTab = computed(() => {
    return tabList.value.find((v) => v.key === activetab.value)
  })
</script>

Vue3渲染出來是醬紫的:

只有一個(gè)殼子,沒有任何內(nèi)容。

問題出在組件的名字上了:在 <script setup> 中要使用動(dòng)態(tài)組件時(shí),需要直接用 :is="Component" 直接綁定到組件本身,而不是字符串的組件名。 也就是需要把'OverviewGraph'改成OverviewGraph即可。 修改后的代碼如下:

<template>
    <component
        :is="currentActiveTab.component"
        ref="componentRef"
        :key="currentActiveTab.key"
        :current-active-tab="currentActiveTab"
        v-bind="currentActiveTab"
    />
</template>
<script setup lang="ts">
import { ref, onMounted, computed, nextTick } from 'vue'
import A from './components/A.vue'
import B from './components/B.vue'
import C from './components/C.vue'

const tabList = ref([
    {
      name: '概覽視圖',
      key: 'all',
      component: OverviewGraph  // 改了這里
    }
  ])
  const activetab = ref('all')
  
  const currentActiveTab = computed(() => {
    return tabList.value.find((v) => v.key === activetab.value)
  })
</script>

到此這篇關(guān)于Vue3動(dòng)態(tài)組件&lt;component&gt;渲染失效原因分析的文章就介紹到這了,更多相關(guān)Vue3 component渲染失效內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue鼠標(biāo)hover(懸停)改變background-color移入變色問題

    vue鼠標(biāo)hover(懸停)改變background-color移入變色問題

    這篇文章主要介紹了vue鼠標(biāo)hover(懸停)改變background-color移入變色問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • vue連接本地服務(wù)器的實(shí)現(xiàn)示例

    vue連接本地服務(wù)器的實(shí)現(xiàn)示例

    本文主要介紹了vue連接本地服務(wù)器的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-01-01
  • vue+ts大文件切片上傳的實(shí)現(xiàn)示例

    vue+ts大文件切片上傳的實(shí)現(xiàn)示例

    在Vue項(xiàng)目中,大圖片和多數(shù)據(jù)Excel等大文件的上傳是一個(gè)非常常見的需求,本文主要介紹了vue+ts大文件切片上傳,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-01-01
  • Vue自定義全局彈窗組件操作

    Vue自定義全局彈窗組件操作

    這篇文章主要介紹了Vue自定義全局彈窗組件操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • vue中v-model指令與.sync修飾符的區(qū)別詳解

    vue中v-model指令與.sync修飾符的區(qū)別詳解

    本文主要介紹了vue中v-model指令與.sync修飾符的區(qū)別詳解,詳細(xì)的介紹了兩個(gè)的用法和區(qū)別,感興趣的可以了解一下
    2021-08-08
  • vue實(shí)現(xiàn)tab切換的3種方式及切換保持?jǐn)?shù)據(jù)狀態(tài)

    vue實(shí)現(xiàn)tab切換的3種方式及切換保持?jǐn)?shù)據(jù)狀態(tài)

    這篇文章主要給大家介紹了關(guān)于vue實(shí)現(xiàn)tab切換的3種方式及切換保持?jǐn)?shù)據(jù)狀態(tài)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-05-05
  • Vue 進(jìn)入/離開動(dòng)畫效果

    Vue 進(jìn)入/離開動(dòng)畫效果

    這篇文章主要介紹了Vue 進(jìn)入/離開動(dòng)畫效果,代碼簡單易懂,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2017-12-12
  • Vue實(shí)現(xiàn)調(diào)用PC端攝像頭實(shí)時(shí)拍照

    Vue實(shí)現(xiàn)調(diào)用PC端攝像頭實(shí)時(shí)拍照

    這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)調(diào)用PC端攝像頭實(shí)時(shí)拍照,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • 示例解析Ant?Design?Vue組件slots作用

    示例解析Ant?Design?Vue組件slots作用

    這篇文章主要為大家通過示例解析Ant?Design?Vue組件slots作用,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • vue項(xiàng)目前端知識(shí)點(diǎn)整理【收藏】

    vue項(xiàng)目前端知識(shí)點(diǎn)整理【收藏】

    本文是小編給大家收藏整理的關(guān)于vue項(xiàng)目前端知識(shí)點(diǎn),非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-05-05

最新評(píng)論