play templage

本文介绍了Play框架中的模板语法,包括变量输出、标签使用、方法调用等,并展示了如何实现模板继承及自定义模板方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1,
${…} -->类似el表达式,可以输出对象的属性,例如

Client ${client.name}


2,
#{tagName /} 标签,例如有 #{script 'jquery.js' /} ,它像Html标签一样,要有结束符,#{script 'jquery.js'}#{/script}
以下是它的例子,意思是通过 list标签遍历一个集合

<h1>Client ${client.name}</h1>
<ul>
#{list items:client.accounts, as:'account' }
<li>${account}</li>
#{/list}
</ul>
#{list items}是固定写法,改成Java应该是这样表达
for(Accounts account : client.accounts)


3,
@{…} or @@{…} 通过这个标记,可以将Play的方法转换成 action的地址
@{....}显示出相对地址
@@{....}显示绝对地址
使用方法例如:

<h1>Client ${client.name}</h1>
<p>
<a href="@{Clients.showAccounts(client.id)}">All accounts</a>
</p>
<hr />
<a href="@{Clients.index()}">Back</a>


4,
Messages : &{…}
国际化标记:
通过在 conf/messages 配置国际信息.
例如:
messages: clientName=The client name is %s

template:<h1>&{'clientName', client.name}</h1>


5,
注释:  *{…}*


6,
%{ }% 标签,和jsp的<%%>标签类似
但是在其中写的语法不是java,好像是Groovy.


1,[size=small;]模板继承
[/size]


使用 
Html代码
#{extends 'xxx.html'}

#{extends 'xxx.html'}

xxx.html中这样写:
Html代码
<h1>Main template</h1>

<div id="content">
#{doLayout /}
</div>

<h1>Main template</h1>

<div id="content">
#{doLayout /}
</div>


在被继承的文件中,写的内容,将会把继承的xxx.html中的
Html代码
#{doLayout /}

#{doLayout /}
替换成被继承文件中写的内容.

2,Create tags(创建模板的公共包含块)
在app/views/tags/文件夹下创建了hello.html,
那么在你定义的模板中可以这么引用它
Html代码
#{hello /}

#{hello /}

给公共包含块中创地参数:
包含块引用的参数前必须以 '_'下划线开头,例如:
Html代码
Hello ${_name} !

Hello ${_name} !
在引用包含块的模板文件中,这么传参数:
Html代码
#{hello name:'Bob' /}

#{hello name:'Bob' /}
如果其中传递多个参数,可以这么传
Html代码
#{hello name:'Bob' password:'asdfasdf' email:'aa@aa.cc' /}

即:
#{hello 参数名:参数对象 ...... ........}可以传很多很多个参数.
其中参数对象可以是个集合或者对象

#{hello name:'Bob' password:'asdfasdf' email:'aa@aa.cc' /}

即:
#{hello 参数名:参数对象 ...... ........}可以传很多很多个参数.
其中参数对象可以是个集合或者对象


如果只传递一个参数:
Play默认提供一个参数名叫做Hello ${_arg}!
你就这么传参数#{hello 'Bob' /},只要传值,不用给参数名即可.

你可以在保护块中使用 Html代码
#{doBody /}

#{doBody /}标记
那么,你在引用包含块的模板中可以
Html代码
#{hello}
Bob
#{/hello}

#{hello}
Bob
#{/hello}

这么写,用Bob替换
Html代码
#{doBody /}

#{doBody /}
的内容。

2,定义自己的模板方法
Html代码
<ul>
#{list items:products, as:'product'}
<li>${product.name}. Price : ${product.price.format('## ###,00')} €</li>
#{/list}
</ul>

<ul>
#{list items:products, as:'product'}
<li>${product.name}. Price : ${product.price.format('## ###,00')} €</li>
#{/list}
</ul>

这里的format方法是Play自带的,我们可以通过继承play.templates.JavaExtensions自定义Play模板的方法.
Java代码
import play.templates.JavaExtensions;

public class CurrencyExtensions extends JavaExtensions {

public static String ccyAmount(Number number, String currencySymbol) {
String format = "'"+currencySymbol + "'#####.##";
return new DecimalFormat(format).format(number);
}
}

import play.templates.JavaExtensions;

public class CurrencyExtensions extends JavaExtensions {

public static String ccyAmount(Number number, String currencySymbol) {
String format = "'"+currencySymbol + "'#####.##";
return new DecimalFormat(format).format(number);
}
}

我们可以这么引用:
Html代码
<em>Price: ${123456.324234.ccyAmount()}</em>

<em>Price: ${123456.324234.ccyAmount()}</em>


你可以通过这么给View传递参数,
在Play的Controller中写
Java代码
renderArgs.put("user", user );

renderArgs.put("user", user );
给页面传递对象,这么使用的像:request.setAttribute("",xxx);
标题基于SpringBoot+Vue的社区便民服务平台研究AI更换标题第1章引言介绍社区便民服务平台的研究背景、意义,以及基于SpringBoot+Vue技术的研究现状和创新点。1.1研究背景与意义分析社区便民服务的重要性,以及SpringBoot+Vue技术在平台建设中的优势。1.2国内外研究现状概述国内外在社区便民服务平台方面的发展现状。1.3研究方法与创新点阐述本文采用的研究方法和在SpringBoot+Vue技术应用上的创新之处。第2章相关理论介绍SpringBoot和Vue的相关理论基础,以及它们在社区便民服务平台中的应用。2.1SpringBoot技术概述解释SpringBoot的基本概念、特点及其在便民服务平台中的应用价值。2.2Vue技术概述阐述Vue的核心思想、技术特性及其在前端界面开发中的优势。2.3SpringBoot与Vue的整合应用探讨SpringBoot与Vue如何有效整合,以提升社区便民服务平台的性能。第3章平台需求分析与设计分析社区便民服务平台的需求,并基于SpringBoot+Vue技术进行平台设计。3.1需求分析明确平台需满足的功能需求和性能需求。3.2架构设计设计平台的整体架构,包括前后端分离、模块化设计等思想。3.3数据库设计根据平台需求设计合理的数据库结构,包括数据表、字段等。第4章平台实现与关键技术详细阐述基于SpringBoot+Vue的社区便民服务平台的实现过程及关键技术。4.1后端服务实现使用SpringBoot实现后端服务,包括用户管理、服务管理等核心功能。4.2前端界面实现采用Vue技术实现前端界面,提供友好的用户交互体验。4.3前后端交互技术探讨前后端数据交互的方式,如RESTful API、WebSocket等。第5章平台测试与优化对实现的社区便民服务平台进行全面测试,并针对问题进行优化。5.1测试环境与工具介绍测试
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值