Twirl模板可以使用class的构造函数方式生成(在template开始处使用 @this(args)语法),而不一定要用object的静态方法。这意味着你可以将Twirl的模板注入到controllers。将控制权从controllers中反转出来。这意味着可以将Twirl模板直接注入到控制器中,由模板来管理自己的依赖,而不是由控制器来管理依赖项以及需要渲染的模板。
举个栗子,假设一个模板依赖了Summarizer组件,并被另一个controller引用:
trait Summarizer {
/** Provide short form of string if over a certain length */
def summarize(item: String)
}
创建一个 app/views/IndexTemplate.scala.html 并使用 @this 构造函数:
@this(summarizer: Summarizer)
@(item: String)
@{summarizer.summarize(item)}
最后使用构造函数注入来定义controller:
public MyController @Inject()(template: views.html.IndexTemplate,
cc: ControllerComponents)
extends AbstractController(cc) {
def index = Action { implicit request =>
val item = "some extremely long text"
Ok(template(item))
}
}
一旦定义了模板,controller就可以注入它,但是 summarizer 对controller是不可见的。
如果你需要在Play项目以外使用Twirl,你需要手动加上如下依赖注入的设置:
TwirlKeys.constructorAnnotations += "@javax.inject.Inject()"
而在Play应用已经为你默认设置好了一切。