玉模板 - 动态调用Mixin

Wal*_*man 5 javascript templates node.js pug

如何使用json中的字符串输入Jade模板来动态加载mixin?下面,目标是twoColumn.jade加载foobar混合.

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)

Tim*_*per 8

这是一个在Jade中不是很明显的功能,因为它没有在文档中明确提到.您实际上可以使用插值语法(#{...})来动态选择mixin名称.

来自玉语言指南:

插值?对!两种类型的文本都可以使用插值,如果我们传递{ name: 'tj', email: 'tj@vision-media.ca' }给编译函数,我们可以执行以下操作:

#user #{name} <#{email}>
Run Code Online (Sandbox Code Playgroud)

输出 <div id="user">tj &lt;tj@vision-media.ca&gt;</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)