`
chenzhihui
  • 浏览: 90201 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Play Framework 的Groovy模板引擎

阅读更多

Play 框架有自己的模板引擎来生成HTML页面,该引擎使用 Groovy 做为表达式语言。你可以直接使用 Groovy 语言来创建动态的网页,但并无需学习 Groovy 所有的知识,你需要了解的只是跟 Java 非常相近的一部分。Play 将所有的模板文件都放在 app/views 目录下,所有页面都是在请求时即时解析的。

接下来我们创建一个简单应用:

oschina@oschina.net:~/dev/play$ /usr/share/play/play new views
~        _            _
~  _ __ | | __ _ _  _| |
~ | '_ \| |/ _' | || |_|
~ |  __/|_|\____|\__ (_)
~ |_|            |__/
~
~ play! 1.0.3, http://www.playframework.org
~
~ The new application will be created in /home/wichtounet/dev/play/views
~ What is the application name? Views
~
~ OK, the application is created.
~ Start it with : play run views
~ Have fun!
~

接下来检查生成的文件,进入 app/views 目录,我们可以看到下面这些内容:

  • Application : 存放应用主 controller 程序的模板
  • errors : 存放错误页面模板,例如 404、500等
  • main.html : 主页面模板

打开  Application/index.html ,代码如下:

#{extends 'main.html' /}
#{set title:'Home' /}
 
#{welcome /}

第一行表明此模板扩展自 main.html,接下来使用了 Play 框架的 set 指令来设置页面的标题,这些指令都要进行关闭,最后一行打印一行欢迎信息。

然后我们再来看看 main.html 模板:

<!DOCTYPE html>
 
<html>
    <head>
        <title>#{get 'title' /}</title>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
        <link rel="stylesheet" type="text/css" media="screen" href="@{'/public/stylesheets/main.css'}">
        #{get 'moreStyles' /}
        <link rel="shortcut icon" type="image/png" href="@{'/public/images/favicon.png'}">
        <script src="@{'/public/javascripts/jquery-1.4.2.min.js'}" type="text/javascript" charset="utf-8"></script>
        #{get 'moreScripts' /}
    </head>
    <body>
        #{doLayout /}
    </body>
</html>

这个模板中包含一些特殊的指令:

  • #{get ‘title’ /} : 获取变量 title 的值,该值仅在模板页面中有效
  • @{‘/public/stylesheets/main.css’} : 引入某个静态资源
  • #{doLayout /} : 此处插入子模板的内容,在本例中就是前面提到的 index.html 页面,index.html 扩展自 main.html

如何在模板间传递参数呢?

传递参数很重要,例如我们在 controller 中读取一些数据,并将这些数据传递到 view 中进行显示。在 Play 框架中可以使用 render 方法来处理,例如:

package controllers;
 
import play.mvc.*;
 
public class Application extends Controller {
    public static void index() {
        String hello = "Hello World from Controller !";
 
        render(hello);
    }
}

index 方法中向模板传递了一个名为 hello 的变量,要在模板中获取这个变量的值,只需 ${hello} 即可:

#{extends 'main.html' /}
#{set title:'Home' /}
 
Hello from the view
<br />
${hello}

怎样,很简单吧?

来个更复杂点的类吧

package models;
 
public class Book {
    private final String title;
 
    public Book(String title) {
        super();
 
        this.title = title;
    }
 
    public String getTitle() {
        return title;
    }
}

然后在 controller 传递此类的实例:

public static void index() {
    Book book = new Book("Hello Play !");
    render(book);
}

接下来在模板中获取该对象

#{extends 'main.html' /}
#{set title:'Home' /}
 
Hello from the view
<br />
I've a book for you "${book.title}".

这里使用了 JavaBean 的 getting 方法,因此我们的Bean 必须有 getTitle 方法。

所有动态内容的输出,Play 框架都做了转码处理,以防止XSS跨站点攻击,如果你不想这样做,那么可使用 raw() 方法,例如

${book.title.raw()}

但这不是一个好习惯,仅在你确认会带来什么后果时才使用。

模板的注释方式如下:

*{Will not be evaluated by the template engine}*

数组和列表

在实际使用过程中,列表和数组是经常要用到的,下面是一个传递列表的实例:

public static void index() {
        List<Book> books = new ArrayList<Book>(3);
        books.add(new Book("Hello Play !"));
        books.add(new Book("Hello Template !"));
        books.add(new Book("Hello Engine !"));
        render(books);
}

模板中使用该列表对象的代码如下:

#{extends 'main.html' /}
#{set title:'Home' /}
I've some books for your :
<ul>
    #{list items:books, as:'book'}
        <li>${book.title}</li>
    #{/list}
</ul>

不是很复杂吧:)

使用JAVA脚本,%{…}% 

如果你需要做更复杂的操作,我们可以在 Groovy 中使用脚本,在脚本中可以定义变量并可直接使用其他变量,例如:

#{extends 'main.html' /}
#{set title:'Home' /}
I've some books for your :
<ul>
    #{list items:books, as:'book'}
        %{
           bookTitle = book.title.toUpperCase();
        }%
        <li>${bookTitle}</li>
    #{/list}
</ul>

你可以做包括迭代、条件等一大堆复杂的事情,但记住,不要在模板中做过于复杂的功能,将这些业务逻辑放在 controller 或者是 models 中,模板应该越简单越好。

定义标签

Play 框架自带很多的标签,但你可以自己创建一些,为了创建标签,我们必须在views目录下创建名为 tags的子目录,例如我们创建一个 booklist.html 文件,存放在 views/tags 目录下,booklist.html 的代码如下:

<ul>
    #{list items:_items, as:'book'}
        %{
            bookTitle = book.title.toUpperCase();
        }%
        <li>${bookTitle}</li>
    #{/list}
</ul>

使用 '_' 来获取参数,本例中是 _items

有了这个自定义的tag,我们就可以将上面那个模板修改为:

#{extends 'main.html' /}
#{set title:'Home' /}
I've some books for your : 
#{booklist items:books /}

尽量利用参数来使得 tag 更加灵活。

接收标签参数: 
标签参数是曝露的模板变量,变量名以下划线开始。如 
Hello ${_name} ! 
使用的时候就可以如下传递标签参数 
#{hello name:'Bob' /} 
如果你的标签只有一个参数,你可以直接使用_arg作为默认参数,它的名字是隐含的。 
Hello ${_arg}! 
调用的时候,也可以同时省略参数名 
#{hello 'Bob' /} 

多语言消息:&{…}用来做国际化 

譬如在conf/messages文件中设置下面的值 
bookName=The book title is %s 
在模板中如下使用: 
<h1>&{'bookName', book.title}</h1> 
注释:*{…}* 注释语法,会被模板引擎自动忽略。 
*{**** Display the book title ****}* 
调用Controller:@{…} 

<a href="@{Application.show(book.id)}">show book</a> 

 

到此我们就介绍了 Play 模板的一些基本的要素,更多关于Play 框架的模板请看官方文档

分享到:
评论

相关推荐

    groovy模板

    groovy模板

    [Groovy入门]第十讲.使用模板引擎开发界面

    [Groovy入门]第十讲.使用模板引擎开发界面

    Play2模板引擎Japid42.zip

    Play1使用groovy模板作为渲染引擎,而Play2使用Scala模板。在Play1时期,Japid作为groovy的替代品,非常受欢迎。而在Play官方使用Scala替换groovy后,性能虽然有所提高,但是限于Scala编译器的性能,仍然远不如Play2...

    Java Web框架Play Framework v2.1.0.zip

    Play Framework是一个full-stack(全栈的)Java Web应用框架,包括一个简单的无状态MVC模型,具有Hibernate的对象持续,一个基于Groovy的模板引擎,以及建立一个现代Web应用所需的所有东西。   Play Framework的...

    Java Web框架Play Framework v2.1.0

    Play Framework是一个full-stack(全栈的)Java Web应用框架,包括一个简单的无状态MVC模型,具有Hibernate的对象持续,一个基于Groovy的模板引擎,以及建立一个现代Web应用所需的所有东西。 Play Framework的关键...

    Java Web框架Play Framework源代码

    Play Framework是一个full-stack(全栈的)Java Web应用框架,包括一个简单的无状态MVC模型,具有Hibernate的对象持续,一个基于Groovy的模板引擎,以及建立一个现代Web应用所需的所有东西。 Play Framework的关键...

    play1.1_API

    是一个full-stack(全栈的)Java Web应用框架,包括一个简单的无状态MVC模型,具有Hibernate的对象持续,一个基于Groovy的模板引擎,以及建立一个现代Web应用所需的所有东西。 Play!的关键特性: 1、一个非常简单...

    Play框架教程

    Play!是一个full-stack(全栈的)Java Web应用框架,包括一个简单的无状态MVC模型,具有Hibernate的对象持续,一个基于Groovy的模板引擎,以及建立一个现代Web应用所需的所有东西。

    One-Ring:Groovy脚本规则引擎服务

    一环-脚本规则引擎服务 一个环与其他“规则引擎...简化或未简化的脚本规则Groovy 保持简单 路线图 该项目自2012年以来未进行更新,并依赖于grails1.3.x。 我们正在寻找一种升级途径,它将其转变为在Micronaut( )上运

    Groovy介绍-入门

    Groovy介绍 什么是Groovy Groovy基本语法 Groovy正则 Java调用Groovy Groovy模板 Groovy应用

    java groovy整合

    1、eclipse安装groovy的插件。 2、创建java project。 3、把groovy-all-2.1.9.jar,加入classpath。 4、编写hello.groovy脚本文件,并在java代码中调用脚本文件 ...

    groovy学习

    NULL 博文链接:https://xiii.iteye.com/blog/1753713

    apache-groovy-3.0.8.zip apache官网的groovy3.0.8版本

    apache-groovy-3.0.8.zip apache官网的groovy3.0.8版本,希望大家多多下载,apache-groovy-3.0.8.zip apache官网的groovy3.0.8版本,希望大家多多下载,apache-groovy-3.0.8.zip apache官网的groovy3.0.8版本,希望...

    groovy-3.0.9-API文档-中文版.zip

    赠送jar包:groovy-3.0.9.jar; 赠送原API文档:groovy-3.0.9-javadoc.jar; 赠送源代码:groovy-3.0.9-sources.jar; 赠送Maven依赖信息文件:groovy-3.0.9.pom; 包含翻译后的API文档:groovy-3.0.9-javadoc-API...

    Learning.Groovy.3.Java-Based.Dynamic.Scripting.2nd.Edition (英文版pdf)

    You'll see how to harness Gradle (Groovy's build system), Grails (Groovy's web application framework), Spock (Groovy's testing framework), and Ratpack (Groovy's reactive web library). What You Will ...

    groovy入门经典,groovyeclipse 插件

    groovy入门经典,groovyeclipse 插件

    [Groovy] Making Java Groovy 英文版

    Making Java Groovy is a practical handbook for developers who want to blend Groovy into their day to day work with Java It starts by introducing the key differences between Java and Groovy and how you...

    Learning Groovy(Apress,2016)

    You’ll see how to harness Gradle (Groovy’s build system), Grails (Groovy’s web application framework), Spock (Groovy’s testing framework), and Ratpack (Groovy’s reactive web library). ...

    Java调用Groovy,实时动态加载数据库groovy脚本

    Java调用Groovy,实时动态加载数据库groovy脚本,java读取mongoDB的groovy脚本,加载实时运行,热部署

    Groovy轻松入门—搭建Groovy开发环境

    Groovy轻松入门—搭建Groovy开发环境 Groovy轻松入门—搭建Groovy开发环境

Global site tag (gtag.js) - Google Analytics