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

如何解決Vue3組合式API模式下動(dòng)態(tài)組件不渲染問(wèn)題

 更新時(shí)間:2024年03月15日 10:03:57   作者:cppandtea  
這篇文章主要介紹了如何解決Vue3組合式API模式下動(dòng)態(tài)組件不渲染問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教<BR>

Vue3可以使用component組件渲染動(dòng)態(tài)組件,將子組件名傳遞給:is指令就可以了。

官方在文檔中指出,傳遞到:is指令的值可以是:

(1)被注冊(cè)的組件名

(2)導(dǎo)入的組件對(duì)象

假設(shè)有以下需求,有以下兩個(gè)子組件,在父組件中需要根據(jù)其他條件動(dòng)態(tài)加載:

<template>
  <h3>我是動(dòng)態(tài)子組件A</h3>
</template>
<style scoped>
h3 {
  background-color: blue;
  color: #fff;
}
</style>

<template>
  <h3>我是動(dòng)態(tài)子組件B</h3>
</template>
<style scoped>
h3 {
  background-color: blueviolet;
  color: #fff;
}
</style>

1. 將動(dòng)態(tài)組件對(duì)象直接賦值給:is

在Vue3組合式API模式下,用component組件渲染動(dòng)態(tài)組件,如果將動(dòng)態(tài)組件對(duì)象直接賦值給:is指令是沒(méi)有問(wèn)題的。

例如以下代碼: 

模板代碼

<template>
  <div>
    <h3>組合API模式下動(dòng)態(tài)組件的加載</h3>
    <component :is="CompA" />
    <component :is="CompB" />
  </div>
</template>

<script setup lang="ts">
import CompA from "./CompA.vue";
</script>

TS代碼

<script lang="ts" setup>
<script setup lang="ts">
import CompA from "./CompA.vue";
import CompB from "./CompB.vue";
</script>

</script>

效果如下,是沒(méi)有問(wèn)題的:

2. 通過(guò)動(dòng)態(tài)組件名的方式賦值給:is無(wú)法實(shí)現(xiàn)

假若需要根據(jù)不同情況賦予:is指令不同的子組件,那么就需要用一個(gè)變量來(lái)存子組件名稱。

在組合api模式下,子組件是無(wú)法渲染的。

因?yàn)閏omponent組件的:is指令需要已注冊(cè)的組件對(duì)象。

請(qǐng)看如下代碼:

<template>
  <div>
    <h3>組合API模式下使用動(dòng)態(tài)組件名加載子組件</h3>
    <template v-for="comp in compArr" :key="comp.compName">
      <component :is="comp.compName" />
    </template>
  </div>
</template>
<script setup lang="ts">
import CompA from "./CompA.vue";
import CompB from "./CompB.vue";
const compArr = [{ compName: "CompA" }, { compName: "CompB" }];
</script>

以上代碼會(huì)引起錯(cuò)誤提示:兩個(gè)導(dǎo)入的子組件未使用:

而且在組合式API模式下,是不能顯式注冊(cè)子組件的,兩個(gè)子組件也并沒(méi)有按我們的預(yù)期渲染出來(lái):

如何解決這個(gè)問(wèn)題呢?

3. 使用組合式和選項(xiàng)式API結(jié)合的方式解決這個(gè)問(wèn)題

在組合式API模式下,Vue是支持多個(gè)Script代碼塊的。

由于選項(xiàng)式API可以顯式注冊(cè)導(dǎo)入的子組件,可以另外寫一個(gè)選項(xiàng)式API模式的script來(lái)顯式注冊(cè)子組件。

這樣在component組件中,傳入已注冊(cè)子組件的名稱即可。

代碼如下:

// 專門定義一個(gè)選項(xiàng)式api模塊,來(lái)注冊(cè)組件
<script lang="ts">
import { defineComponent } from "vue";
import CompA from "./CompA.vue";
import CompB from "./CompB.vue";
export default defineComponent({
  components: { CompA, CompB }
});
</script>

<script setup lang="ts">
const compArr = [{ compName: "CompA" }, { compName: "CompB" }];
</script>

兩個(gè)子組件已經(jīng)成功渲染了。

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論