如何更改mustache.js的默认分隔符



有人能告诉我如何改变胡子的默认分隔符。js?默认分隔符是{{var}},我想将其更改为{|var|}

我有以下代码:

$('body').append(Mustache.render(this.template, data));

多谢

根据文档:

设置分隔符标记以等号开始,并将标记分隔符从{{和}}更改为自定义字符串。考虑下面这个人为的例子:

* {{ default_tags }}
{{=<% %>=}}
* <% erb_style_tags %>
<%={{ }}=%>
* {{ default_tags_again }}

如果你想使用{|var|}你可以使用:

{{={| |}=}}

注意,这里是另一个将默认分隔符更改为三重分隔符的示例。

我想一个javascript的例子也会很有帮助。

var template = $('#template').html();
var parseTags = new Array();
parseTags.push("[[");
parseTags.push("]]");
Mustache.parse(template,parseTags);   // optional, speeds up future uses
var rendered = Mustache.render(template, {name: "<%Luke%>"});

在app.js中,使用下面代码片段中的最后一行。前2条供参考:

// view engine setup
app.set('views', path.join(__dirname, 'views/templates'));
app.set('view engine', 'hjs');
app.locals.delimiters = '{| |}';

现在有一种更简洁的方法可以做到这一点,并且有很好的文档说明。https://github.com/janl/mustache.js/

var customTags = [ '<%', '%>' ];
Mustache.render(template, view, {}, customTags);
//Either tell mustache to use them each time
Mustache.render(template, view, {}, customTags);
//Or override the tags property and Mustache knows what to do until you tell it otherwise
Mustache.tags = customTags;
var updateTemplate = '<small class="text-muted">Last updated <% updated_at %> by <% updated_by %></small>';
var html = Mustache.render(updateTemplate, {updated_at:'2019-11-18 14:54:20',updated_by:'abc'});

最新更新