Play 有一套高效的模版系统,它可以由有格式的文本来动态的生成Html,Xml,JSON或者其他文本。它的Template Engine使用Groovy作为表达式语言。
以下举几个例子:
1.Expressions : ${…}
<h1>Client ${client.name}</h1>
2.Tags : #{tagName /}
#{script 'jquery.js' /}
也可以写成:
#{script 'jquery.js'}#{/script}
迭代标签:
<h1>Client ${client.name}</h1>
<ul>
#{list items:client.accounts, as:'account' }
<li>${account}</li>
#{/list}
</ul>
3.Actions : @{…} or @@{…}
使用Router 来把URL转换成相当应的route,@{…} 这个标签就可以完成
这个功能。
<h1>Client ${client.name}</h1>
<p>
<a href="@{Clients.showAccounts(client.id)}">All accounts</a>
</p>
<hr />
<a href="@{Clients.index()}">Back</a>
@@{…}用法一样而且可以生成绝对路径(尤其是有用的Emial)
4.Messages : &{…}
国际化标签, 在conf下建message文件.
写下:clientName=The client name is %s
使用:<h1>&{'clientName', client.name}</h1>
5.Comment : *{…}*
注释标签: *{**** Display the user name ****}*
6.Scripts : %{…}%
脚本标签: 脚本是一个更为复杂的表达式,可以用来定义一些变量和语句。
%{
fullName = client.name.toUpperCase()+' '+client.forname;
}%
<h1>Client ${fullName}</h1>
脚本可以直接使用out对象写动态的内容:
%{
fullName = client.name.toUpperCase()+' '+client.forname;
out.print('<h1>'+fullName+'</h1>');
}%
你也可以在你的模版里使用脚本创建譬如iteration的结构:
<h1>Client ${client.name}</h1>
<ul>
%{
for(account in client.accounts) {
}%
<li>${account}</li>
%{
}
}%
</ul>
以下举几个例子:
1.Expressions : ${…}
<h1>Client ${client.name}</h1>
2.Tags : #{tagName /}
#{script 'jquery.js' /}
也可以写成:
#{script 'jquery.js'}#{/script}
迭代标签:
<h1>Client ${client.name}</h1>
<ul>
#{list items:client.accounts, as:'account' }
<li>${account}</li>
#{/list}
</ul>
3.Actions : @{…} or @@{…}
使用Router 来把URL转换成相当应的route,@{…} 这个标签就可以完成
这个功能。
<h1>Client ${client.name}</h1>
<p>
<a href="@{Clients.showAccounts(client.id)}">All accounts</a>
</p>
<hr />
<a href="@{Clients.index()}">Back</a>
@@{…}用法一样而且可以生成绝对路径(尤其是有用的Emial)
4.Messages : &{…}
国际化标签, 在conf下建message文件.
写下:clientName=The client name is %s
使用:<h1>&{'clientName', client.name}</h1>
5.Comment : *{…}*
注释标签: *{**** Display the user name ****}*
6.Scripts : %{…}%
脚本标签: 脚本是一个更为复杂的表达式,可以用来定义一些变量和语句。
%{
fullName = client.name.toUpperCase()+' '+client.forname;
}%
<h1>Client ${fullName}</h1>
脚本可以直接使用out对象写动态的内容:
%{
fullName = client.name.toUpperCase()+' '+client.forname;
out.print('<h1>'+fullName+'</h1>');
}%
你也可以在你的模版里使用脚本创建譬如iteration的结构:
<h1>Client ${client.name}</h1>
<ul>
%{
for(account in client.accounts) {
}%
<li>${account}</li>
%{
}
}%
</ul>