繁体   English   中英

使用Node.js,Handlebars和Express进行模板继承

[英]Template inheritance with Node.js, Handlebars and Express

我刚刚开始使用Node.js,所以我正在构建非常简单的应用程序以便练习基础知识。 我试图让一些像Django一样的模板继承工作,但我对如何做它有点不知所措。

据我所知,图书馆“快递把手”包含了布局的概念,我认为这可能是最好的方法,但乍一看我不知道它是否允许不止一步的继承,或者使用它来替换不同的块(我看到了插入其他模板的一般布局代替{{{body}}}标签,尽管可能有更多的技巧)。

所以,我的问题是:如何实现多层模板继承(同样,将子内容插入不同的单独块,而不是单个块)? 我正在使用Node.js,Express和把手,但如果后两者不可能,我不介意尝试其他框架或模板语言。

谢谢!

编辑:

我的意思的伪编码示例:

首先,我们可以有一个共同的外部模板:

<html>
    <head></head>
    <body>
        <h1> Main Title </h1>
        <h2> {{section name block}} </h2>
        <h3> {{subsection name block}} </h3>
        {{content block}}
    </body>
</html>

然后在它下面的另一个(中间模板),替换一些外部的块(并可能添加其他块):

{{inheriting from outer template}}
{{section name block}} Section Three {{/block}}

最后是一个内部的,它将是从javascript代码调用的那个:

{{inheriting from middle template}}
{{subsection name block}} Subsection Two {{/block}}
{{content block}}
    <p>This is the content of Section Three, Subsection Two.</p>
{{/block}}

处理内部模板时的结果是:

<html>
    <head></head>
    <body>
        <h1> Main Title </h1>
        <h2> Section Three </h2>
        <h3> Subsection Two </h3>
        <p>This is the content of Section Three, Subsection Two.</p>
    </body>
</html>

它不是100%清楚你要求的模板术语“继承”,但手柄模板可以包括模板,其中可以包含其他模板,其中可以包含模板,以便您可以根据需要进行嵌套。

例如,我只使用语法:

{{> common_header}}

common_header模板嵌入当前模板中。 common_header本身可以嵌入其他模板,依此类推。


您还可以使用布局( 此处讨论),它允许您拥有类似于母版的模板,可以将不同的内容呈现到该模板中。


FYI,还有使用车把上的Django类模板继承的讨论, 在这里这里和布局扩展把手在这里和在车把使用的布局更多的讨论在这里


Swig似乎有这个功能

http://paularmstrong.github.io/swig/docs/#inheritance

没有亲自使用它,但看起来像PHP的Twig一样的继承语法,所以应该没问题

任何登陆此问题的人都可能想知道这一点:正如他们的github所说,不再支持Swig

也就是说, Nunjucks看起来是Javascript中可扩展模板的唯一选择。 语法非常类似于Twig(PHP)

我希望这有帮助

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM