用表达式时,以下使用时,只有client不为null的状况下,才进行client.name的输出。css
<h1>Client ${client?.name}</h1>
在应用中,模板引擎默认对全部的动态表达式进行转义,以此来避免XSS的安全问题。能够经过调用扩展方法raw(),以非转义的形式在页面中输出,如:html
${title.raw()} --> <h1>Title</h1>
若是须要显示大量的非转义HTML内容,可使用#{verbatim /}标签:java
#{verbatim} ${title} --> <h1>Title</h1> #{/verbatim}
Play经过路由器能够(逆向)生成URL,匹配指定的路由。在模板中使用@{…}引用能够达到相同的目的:安全
<h1>Client ${client.name}</h1> <p><a href="@{Clients.showAccounts(client.id)}">All accounts</a></p> <hr /> <a href="@{Clients.index()}">Back</a>
该实例中,@{Clients.showAccounts(client.id)}调用了Clients控制器中的showAccounts Action方法,并传递了client.id参数。 @@{…}引用的使用语法与@{…}相同,只不过生成的是绝对URL(尤为适用于邮箱)。服务器
Play中,能够 使用#{extends /} 和 #{doLayout /}来继承模板,使用#{get}和#{set}标签进行参数传递,如:session
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> <head> <title>#{get 'title' /}</title> <link rel="stylesheet" type="text/css" href="@{'/public/stylesheets/main.css'}" /> </head> <body> <h1>#{get 'title' /}</h1> #{doLayout /} <div class="footer">Built with the play! framework</div> </body> </html>
其余页面使用#{extends}标签能够很是简单地植入该装饰模板,具体使用方法以下:并发
#{extends 'simpledesign.html' /} #{set title:'A decorated page' /} This content will be decorated.
该子模板使用#{extends 'simpledesign.html' /}标签来继承simpledesign.html,使用#{set title:'A decorated page' /}标签传递页面的title变量,最后在页面中输出This content will be decorated。mvc
#{a} Play须要经过路由器(逆向)生成URL,以此来调用指定的Action。框架封装了HTML中的超连接标签<a>,能够方便地调用控制器中的Action,如:app
#{a @Application.index()} 首页 #{/a}
#{authenticityToken /} 使用#{authenticityToken /}标签能够防止跨站请求伪造,同时也能消除刷新提交和后退提交所带来的困扰。#{authenticityToken /}首先会为服务器和客户端表单生成相同的随机令牌,并以隐藏的input输入域的形式嵌入表单。当用户点击submit按钮提交时,令牌会伴随着表单信息一并发送至控制器中的Action,在Action对提交的表单进行处理前,会先进行令牌的比对,只有令牌信息一致时,才进行后续的表单处理操做。框架
#{authenticityToken /}
#{field} #{field}标签的做用很是大,本着Play的“简约”理念,#{field}标签能够帮助开发者减小同一变量名的重复使用:
#{field 'user.name'} <p> <label>&{field.name}</label> <input type="text" id="${field.id}" name="${field.name}" value="${field.value}" class="${field.errorClass}"> <span class="error">${field.error}</span> </p> #{/}
Field.name 是user.name, filed.value是user.name的值。Play提倡在页面开发中尽可能使用#{field}标签,而不是重复地编写变量名。 #{i18n} i18n在模板中的用法比较特殊,不只能够直接以标签的形式用于模板语言,也能够直接在JavaScript中调用。能够在JavaScript代码中使用i18n()方法来访问本地化消息文件,如i18n('app_title')。 引入
#{i18n /}
在Js中使用
alert(i18n('hello_world')); alert(i18n('hello_someone', 'John'));
#{set},#{get} #{set}标签用于设置能够在模板中使用的变量。如 #{set email:'china@oopsplay.org'}
,就设置了模板变量email的值,能够经过 #{get 'email'}
来获取。#{set}标签的定义中能够引用其余变量。
在模板引擎中使用Java对象是必不可少的,开发者还能够为其增长一些额外的方法。这些方法并无定义在原始的Java类中,而是模板引擎动态添加的。下面是一些比较有用的扩展:
${['red', 'green', 'blue'].join('/')} //合并 效果 red/green/blue ${['red', 'green', 'blue'].last()} //返回最后一个元素 ,效果 blue ${new Date(1275910970000).format('dd MMMM yyyy hh:mm:ss')} //07 June 2010 01:42:50 ${new Date(new Date().getTime() - 1000000).since()} //多久以前 16 minutes ago ${1275910970000.asdate('dd MMMM yyyy hh:mm:ss', 'fr')} //07 juin 2010 01:42:50 ${[id:'42', color:'red'].asAttr()} //属性表示方式,效果 id="42" color="red" html ${42.format('000.00')} // 042.00 ${42.page(10)} //页数计算 ${"lorum ipsum dolor".capAll()} // Lorum Ipsum Dolor ${"lorum ipsum dolor".cut('um')} // lor ips dolor ${"The <blink>tag</blink> is evil".escape().raw()} //The <blink>tag</blink> is evil ${(["red", "green", "blue"] as String[]).add('pink').join(' ')} //red green blue pink ${(['red', 'green', 'blue'] as String[]).contains('green')} //true ${(['red', 'green', 'blue'] as String[]).remove('green').join(' ')} //red blue
Play中全部的内置对象: errors 验证错误信息结果集,对应play.data.validation.Validation.errors() flash Flash做用域,对应play.mvc.Scope.Flash lang 当前使用的语言,对应play.i18n.Lang messages 消息映射变量,对应play.i18n.Messages out 引用页面输出流,对应java.io.PrintWriter params 当前参数变量,对应play.mvc.Scope.Params play Play框架类,对应play.Play request 当前请求对象,对应play.mvc.Http.Request session Session做用域,对应play.mvc.Scope.Session