我正在编写一个带有孩子的自定义 Blaze 块助手:
<template name="parent">
{{> Template.contentBlock ..}}
</template>
<template name="child">
{{> Template.contentBlock ..}}
</template>
我的预期用例是有一个带有任意子节点的模板,我在 html 文件中定义。
{{#parent}}
{{#child id="child1" title="Child 1"}}
<p>This is content of child 1</p>
{{/child}}
{{#child id="child2" title="Child 2"}}
<p>This is content of child 2</p>
{{/child}}
{{#child id="childN" title="Child N"}}
<p>This is content of child N</p>
{{/child}}
{{/parent}}
到目前为止没有问题。但是,在父模板的onCreated
/autorun
我想访问child
模板。我想使用这些数据在父模板元素中动态创建,基于
Template.parent.onCreated(function () {
const instance = this;
instance.state = new ReactiveDict();
instance.autorun(function () {
const contentBlocks = // how?
instance.state.set("children", contentBlocks);
});
});
Template.parent.helpers({
children() {
return Template.instance().state.get("children");
}
});
模板中将在哪里children
使用,parent
如下所示:
{{#parent}}
{{#each children}}
do something with {{this.value}}
{{/each}}
{{#child id="child1" title="Child 1"}}
<p>This is content of child 1</p>
{{/child}}
{{#child id="child2" title="Child 2"}}
<p>This is content of child 2</p>
{{/child}}
{{#child id="childN" title="Child N"}}
<p>This is content of child N</p>
{{/child}}
{{/parent}}
我不想要的是访问 contentBlock 的内容(the <p>
),而是获取已添加child
模板的列表。
当前的 Template / Blaze API 有可能吗?在这一点上,文档有点薄。
它基本上与这篇文章相反:How to get the parent template instance (of the current template)
编辑 1:使用父视图的渲染功能(仅部分工作)
我找到了一种方法来获取parent
模板的孩子,但不是他们的data
反应:
// in Template.parant.onCreated -> autorun
const children = instance.view.templateContentBlock.renderFunction()
.filter(child => typeof child === 'object')
.map(el => Blaze.getData(el._render()));
console.log(children);
// null, null, null because Blaze.getData(view) does return null
我发现的另一种方法是使用 sharedReactiveVar
但在我看来两者都不够干净。我只想获取父级js代码中的模板实例列表。
编辑 2:使用共享的 ReactiveVar(仅部分工作)
ReactiveVar
只要在两个模板的范围内,就可以使用共享:
const _cache = new ReactiveVar({});
Template.parent.onCreated(function () {
const instance = this;
instance.state = new ReactiveDict();
instance.autorun(function () {
const children = Object.values(_cache.get());
instance.state.set("children", children);
});
});
Template.parent.helpers({
children() {
return Template.instance().state.get("children");
}
});
工作(但只渲染一次,没有反应):
Template.child.onCreated(function () {
const instance = this;
const data = Template.currentData();
const cache = _cache.get();
cache[data.id] = data;
_cache.set(cache);
});
不工作(子自动运行正在设置值,但未呈现新值):
Template.child.onCreated(function () {
const instance = this;
instance.autorun(function() {
const instance = this;
const data = Template.currentData();
const cache = _cache.get();
cache[data.id] = data;
_cache.set(cache);
});
});