gpt4 book ai didi

javascript - 如何编译内联 HTMLBars 模板?

转载 作者:行者123 更新时间:2023-11-29 19:28:49 27 4
gpt4 key购买 nike

我有一个内联模板(JavaScript 中的模板),我曾经像这样编译(其中 temp 是一个 Handlebars 字符串):

var template = Handlebars.compile(temp);
template({model: results}); // Gets the HTML

我正在尝试改用 HTMLBars,但不太明白。我做了以下事情:

var template = Ember.HTMLBars.compile(temp);
template({model: results}); // Throws an error that template isn't a function

如何从 HTMLBars 模板中取回 HTML。我也试过:

var template = Ember.HTMLBars.compile(temp);
Ember.HtmlBars.template(template, {model: results});

这不会出错,但在呈现 HTML 时也不会使用该模型。我想我很接近,但不太清楚如何注入(inject)模型。

最佳答案

HTMLBars 不像 Handlebars 那样产生函数。 Handlebars 是一种字符串模板语言:将字符串编译为模板函数,然后运行该函数生成字符串。 HTMLBars 将字符串编译成模板,但模板不生成字符串,它生成 DOM 节点。简单的答案是,您将无法像使用 Handlebars 那样使用 HTMLBars 做同样的事情。我建议在代码中添加另一个字符串模板库(可能是 Handlebars),或者让 View 处理 HTMLBars 模板,如 this question 中所示。 .

如果你很好奇,下面是 HTMLBars 模板对象在编译后的样子(从 JSBin 控制台转储中获取):

[object Object] {
blockParams: 0,
build: function build(dom) {
var el0 = dom.createDocumentFragment();
var el1 = dom.createTextNode("");
dom.appendChild(el0, el1);
var el1 = dom.createTextNode("");
dom.appendChild(el0, el1);
return el0;
},
cachedFragment: null,
hasRendered: false,
isHTMLBars: true,
isMethod: false,
isTop: true,
render: function render(context, env, contextualElement) {
var dom = env.dom;
var hooks = env.hooks, content = hooks.content;
dom.detectNamespace(contextualElement);
var fragment;
if (env.useFragmentCache && dom.canClone) {
if (this.cachedFragment === null) {
fragment = this.build(dom);
if (this.hasRendered) {
this.cachedFragment = fragment;
} else {
this.hasRendered = true;
}
}
if (this.cachedFragment) {
fragment = dom.cloneNode(this.cachedFragment, true);
}
} else {
fragment = this.build(dom);
}
if (this.cachedFragment) { dom.repairClonedNode(fragment,[0,1]); }
var morph0 = dom.createMorphAt(fragment,0,1,contextualElement);
content(env, morph0, context, "foo");
return fragment;
}
}

关于javascript - 如何编译内联 HTMLBars 模板?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29403103/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com