vue3中如何动态自定义创建组件并挂载

简介: vue3中如何动态自定义创建组件并挂载

在日常开发中,我们可能会遇到一种情况:组件太灵活,且无法预先定义。那么我们就需要能够创建组件的能力,并且能组合到我们现有的界面中。

基础API
// 创建

app.component(name, {
   })

// 组合


很多人看到这里应该就大致知道怎么做了,后面的示例可以直接略过~

示例
集成一个创建组件的方法

import {
    createApp } from 'vue';
import {
    TComponent } from './type';

export const createVueComponent = (component: TComponent) => {
   
    const app = createApp({
   });
    app.component(component.name, {
   
        template: component.template,
        data: () => component.data || {
   },
        props: component.props || {
   },
        methods: component.methods,
        onMounted: component.onMounted,
    });
    return app.component(component.name);
};

使用场景
这里正在向低代码扩展,所以只能存储字符串,那么这里就得有能利用字符串创建组的能力。

<!-- 自定义内容 -->
 <template v-else-if="item.slot">
   <!-- 低代码:利用字符串创建新的组件 -->
   <component v-if="(typeof item.slot === 'object')" 
     :is="createVueComponent({ name: item?.slot?.name || '', template: item.slot.template, props: item.slot.props  })" 
     :row="scope.row" :index="scope.$index" :label="item.label" ></component>
   <!-- 当组件使用 -->
   <slot v-else :name="'zh-table-' + item.prop" :row="scope.row" :index="scope.$index" :label="item.label" />
 </template>
相关文章
|
6天前
|
存储 JavaScript 开发者
Vue 组件间通信的最佳实践
本文总结了 Vue.js 中组件间通信的多种方法,包括 props、事件、Vuex 状态管理等,帮助开发者选择最适合项目需求的通信方式,提高开发效率和代码可维护性。
|
6天前
|
存储 JavaScript
Vue 组件间如何通信
Vue组件间通信是指在Vue应用中,不同组件之间传递数据和事件的方法。常用的方式有:props、自定义事件、$emit、$attrs、$refs、provide/inject、Vuex等。掌握这些方法可以实现父子组件、兄弟组件及跨级组件间的高效通信。
|
15天前
|
JavaScript 数据管理 Java
在 Vue 3 中使用 Proxy 实现数据双向绑定的性能如何?
【10月更文挑战第23天】Vue 3中使用Proxy实现数据双向绑定在多个方面都带来了性能的提升,从更高效的响应式追踪、更好的初始化性能、对数组操作的优化到更优的内存管理等,使得Vue 3在处理复杂的应用场景和大量数据时能够更加高效和稳定地运行。
36 1
|
15天前
|
JavaScript 开发者
在 Vue 3 中使用 Proxy 实现数据的双向绑定
【10月更文挑战第23天】Vue 3利用 `Proxy` 实现了数据的双向绑定,无论是使用内置的指令如 `v-model`,还是通过自定义事件或自定义指令,都能够方便地实现数据与视图之间的双向交互,满足不同场景下的开发需求。
36 1
|
JavaScript
Vue的非父子组件之间传值
全局事件总线 一种组件间通信的方式,适用于任意组件间通信
|
缓存 JavaScript 前端开发
Vue Props、Slot、v-once、非父子组件间的传值....
Vue Props、Slot、v-once、非父子组件间的传值....
84 0
|
JavaScript
Vue中父子组件传值
先在⽗组件中给⼦组件的⾃定义属性绑定⼀个⽗组件的变量
|
JavaScript
vue 组件传值
vue 组件传值
82 0
|
JavaScript
vue父子组件传值
vue父子组件传值
|
JavaScript
vue兄弟组件传值 方便快捷
vue兄弟组件传值 方便快捷

相关实验场景

更多