我有一个插槽的以下组件:
<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);
原文地址:https://www.jb51.cc/js/157650.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。