我正在计划我的网站结构如下:
- header.scala.html
- XXX
- 页脚.scala.html
现在,应该有一个特定页面而不是“xxx”(即“UsersView.scala.html”)。
我需要的是将页脚和页眉的来源(与众所周知的语言一样)包含在中间页面的代码中。
所以我的问题是:
- 你如何使用 scala 模板在另一个页面中包含一个页面?
- 你认为这是一个很好的 Play 范例!基于框架的网站?
我正在计划我的网站结构如下:
- header.scala.html
- XXX
- 页脚.scala.html
现在,应该有一个特定页面而不是“xxx”(即“UsersView.scala.html”)。
我需要的是将页脚和页眉的来源(与众所周知的语言一样)包含在中间页面的代码中。
所以我的问题是:
只需像方法一样调用另一个模板。如果你想包含footer.scala.html:
@footer()
一种常见的模式是创建一个包含样板的模板,并采用 HTML 类型的参数。比方说:
main.scala.html
@(content: HTML)
@header
// boilerplate
@content
// more boilerplate
@footer
实际上,您并不需要使用这种方法分离页眉和页脚。
您的 UsersView.scala.html 然后看起来像这样:
@main {
// all your users page html here.
}
您通过将用户视图作为参数传递给 main 来包装用户视图。
您可以在示例中看到这样的示例
我通常的主模板涉及更多内容,大致如下所示:
@(title: String)(headInsert: Html = Html.empty)(content: Html)(implicit user: Option[User] = None)
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8" />
<title>@title</title>
// bootstrap stuff here
@headInsert
</head>
<body>
@menu(user)
<div id="mainContainer" class="container">
@content
</div>
</body>
</html>
这样,模板可以传入头部插入和标题,并使用户可用,当然还有内容。
Play 提供了一种非常方便的方式来帮助实现它!
官方文档中的布局部分:
首先我们有一个base.html(这是我们在django中调用的-_-)
// views/main.scala.html
@(title: String)(content: Html)
<!DOCTYPE html>
<html>
<head>
<title>@title</title>
</head>
<body>
<section class="content">@content</section>
</body>
</html>
如何使用base.html?
@main(title = "Home") {
<h1>Home page</h1>
}
更多信息在这里