如何在mustache中使用嵌套模板?有没有相应的方法可以实现?
var tmpl="{{#data}}
{{values}}
Name: {{name}}
//{{another_templ({{name.value}})}}
{{/values}}
{{/data}}"
希望大家已经明白了问题。由于代码分散在不同的行中,我没有添加JS有效性的转义字符。如何在mustache中使用嵌套模板?有没有相应的方法可以实现?
var tmpl="{{#data}}
{{values}}
Name: {{name}}
//{{another_templ({{name.value}})}}
{{/values}}
{{/data}}"
希望大家已经明白了问题。由于代码分散在不同的行中,我没有添加JS有效性的转义字符。function nested_template(template_string, translate) {
return function() {
return function(text, render) {
return Mustache.to_html(template_string, translate(render(text)));
};
};
}
var template_string =
"{{#data}}"+
"{{values}}"+
"Name: {{name}}"+
"{{#another_templ}}{{name}}{{/another_templ}}"+
"{{/values}}"+
"{{/data}}";
var another_template_string = "<b>{{name}}</b>"; // for example
var view = {
data: {
values: {
name: "Test"
}
},
another_templ: nested_template(another_template_string, function(text) {
return {name: text};
});
};
var result = Mustache.to_html(template_string, view);
{{>partial}}
来实现的。 - Pere{{another_tpl({{name}})}}
。所有答案都解释了如何做到这一点。想象一个通用的模板,例如用于使文本旁边有一个小图标以调用搜索功能。像这样的东西应该可用于任何文本,包括通过moustache自身生成的文本。如何使用partials解决这个问题? - marc<div class="main"><!-- content here --></div>
<script type="text/html" id="tpl"></script>
<script type="text/html" id="tpl-nested"></script>
function renderNested(template_string, translate) {
return function() {
return function(text, render) {
return Mustache.to_html(template_string, translate(render(text)));
};
};
}
var template = $("#tpl").html();
var nested_template = $("#tpl-nested").html();
var model = {
data: {
names: [
{ name: "Foo" },
{ name: "Bar" }
],
nested: renderNested(nested_template, function(text) {
return { name: text };
})
}
};
var result = Mustache.to_html(template, model);
$(".main").html( result );
这里有一种方法,我们在编译模板之前进行字符串替换。 子模板通过以下方式在模板中调用: {{#template}}插入您的子模板名称{{/template}}
templates = {}
function compileTemplates(templateNamesArray) {
for (index in templateNamesArray) {
var templateName = templateNamesArray[index];
var baseHTML = $('#' + templateName).html();
var start = baseHTML.indexOf("{{#template}}");
while(start != -1) {
var end = baseHTML.indexOf('{{/template}}', start);
var nestedTemplateName = baseHTML.slice(start + "{{#template}}".length, end);
var nestedTemplateEl = $('#' + nestedTemplateName);
if (nestedTemplateEl.length == 0) {
throw "Could not find nested template '" + nestedTemplateName + "' for the template '" + templateName + "'";
}
baseHTML = baseHTML.slice(0, start) + nestedTemplateEl.html() + baseHTML.slice(end + '{{/template}}'.length);
start = baseHTML.indexOf("{{#template}}", start);
}
templates[templateName] = Handlebars.compile(baseHTML);
}
}
compileTemplates(["templateActiveThreadTab", "templateActiveThreadContent", "templateTodoItem"]);