javascript – 如何以编程方式创建Vue.js插槽?

我有一个插槽的以下组件:
<template>
    <div>
        <h2>{{ someProp }}</h2>
        <slot></slot>
    </div>
</template>

出于某些原因,我必须手动实例化此组件.这就是我这样做的方式:

const Constr = Vue.extend(MyComponent);
const instance = new Constr({
    propsData: { someProp: 'My heading' }
}).$mount(body);

问题是:我无法以编程方式创建插槽内容.到目前为止,我可以创建基于字符串的简单插槽:

const Constr = Vue.extend(MyComponent);
const instance = new Constr({
    propsData: { someProp: 'My heading' }
});

// Creating simple slot
instance.$slots.default = ['Hello'];

instance.$mount(body);

问题是 – 如何以编程方式创建$slots并将其传递给我使用new创建的实例?

注意:我没有使用完整版本的Vue.js(仅限运行时).所以我没有可用的Vue.js编译器来动态编译模板.

解决方法

我查看了Vue.js的TypeScript定义文件,并在Vue组件实例上找到了一个未记录的函数:$createElement().我的猜测是,它是传递给组件的render(createElement)函数的相同函数.所以,我能够解决它:
const Constr = Vue.extend(MyComponent);
const instance = new Constr({
    propsData: { someProp: 'My heading' }
});

// Creating simple slot
const node = instance.$createElement('div',['Hello']);
instance.$slots.default = [node];

instance.$mount(body);

但这显然没有记载,因此有问题的方法.如果有更好的方法,我不会给它回答.

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...