Wal*_*man 5 javascript templates node.js pug
如何使用json中的字符串输入Jade模板来动态加载mixin?下面,目标是twoColumn.jade加载foo和bar混合.
twoColumn.jade
mixin twoColumns(obj)
.container-fluid
.row(class=obj.class)
for item in obj.items
.col-xs-12.col-sm-3
//- Syntax for dynamically calling a mixin?
+item.template(item)
Run Code Online (Sandbox Code Playgroud)
content.json
{
"twoColumns": {
"class": "foobar",
"items": [
{
"template": "foo",
"title": "Hello"
},
{
"template": "bar",
"title": "World"
}
]
}
}
Run Code Online (Sandbox Code Playgroud)
这是一个在Jade中不是很明显的功能,因为它没有在文档中明确提到.您实际上可以使用插值语法(#{...})来动态选择mixin名称.
来自玉语言指南:
插值?对!两种类型的文本都可以使用插值,如果我们传递
{ name: 'tj', email: 'tj@vision-media.ca' }给编译函数,我们可以执行以下操作:Run Code Online (Sandbox Code Playgroud)#user #{name} <#{email}>输出
<div id="user">tj <tj@vision-media.ca></div>
用法示例:
mixin foo(item)
p Foo called
mixin bar(item)
p Bar called
mixin twoColumns(obj)
.container-fluid
.row(class=obj.class)
for item in obj.items
.col-xs-12.col-sm-3
+#{item.template}(item)
Run Code Online (Sandbox Code Playgroud)