Gsp
接触到了groovy开发,自然就接触到了gsp。在grails开发中,gsp作为Grails的视图技术,事实上, 不过是标准 HTML 加上一些提供动态内容的 Grails 标记而已。
gsp--Groovy Servers Pages ,它被设计成像ASP和JSP这样被使用者熟悉的技术,但更加灵活和直观。
GSP存在于Grails的grails-app/views目录中,他们通常会自动渲染(通过规约),或者像这样通过render方法:
render(view:"index")
一个GSP是典型的混合标签和GSP指令来帮助视图渲染。 一个GPS通常拥有一个"model",它是变量集被用于视图渲染。通过一个控制器model被传递到GSP视图。
GSP支持使用 <% %>来嵌入Groovy代码(这是不推荐的): 同样,你可以使用<%= %>语法来输出值:GSP同样支持服务器端JSP样式注释。在GSP中存在着一些预先定义的变量,包括:
application - javax.servlet.ServletContext实例
applicationContext Spring ApplicationContext实例
flash - flash 对象
grailsApplication - GrailsApplication 实例
out - 响应输出流
params -params对象用于检索请求参数
request - HttpServletRequest实例
response - HttpServletResponse实例
session - HttpSession实例
webRequest - GrailsWebRequest实例
GSP的表达式跟JSP EL表达式很相似的,跟Groovy GString的${expr}用法也很像,跟JSP EL不同的是,你可以在${..}括号中使用Groovy表达式。${..}中的变量缺省情况下是不被转义的,因此变量的任何HTML字符串内容被直接输出到页面,要减少这种Cross-site-scripting (XSS)攻击的风险,你可以设置grails-app/conf/Config.groovy中的 grails.views.default.codec为HTML转化方式。
grails.views.default.codec='html'
GSP标签-----------------------------------------------------
所有GSP内置标签以前缀g:开始。不像JSP,你不需要指定任何标签库的导入。假如,一个标签以g:开始,它被自动认为是一个GSP标签。
变量可以被放置于下列的范围内: 选择变量被放入的范围可以使用scope属性
GSP同样支持迭代逻辑标签,逻辑上通过使用if, else 和 elseif来支持典型的分支情形。GSP用each和while 标签来处理迭代。
假如你拥有对象集合,你经常需要使用一些方法来排序和过滤他们。GSP支持findAll 和 grep来做这些工作。
Stephen King's Books:
<g:findAll in="${books}" expr="it.author == 'Stephen King'">
<p>Title: ${it.title}</p>
</g:findAll>
expr属性包含了一个Groovy表达式,它可以被当作一个过滤器来使用。谈到过滤器,grep标签通过类来完成与过滤器类似的工作:
<g:grep in="${books}" filter="NonFictionBooks.class">
<p>Title: ${it.title}</p>
</g:grep>
或者使用一个正则表达式:GSP还拥有特有的标签来帮助你管理连接到控制器和操作.link标签允许你指定控制器和操作
<g:grep in="${books.title}" filter="~/.*?Groovy.*?/">
<p>Title: ${it}</p>
</g:grep>
配对的名字,并基于URL映射来自动完成连接。即使你去改变!一些 link的示例如下:
<g:link action="show" id="1">Book 1</g:link>
<g:link action="show" id="${currentBook.id}">${currentBook.name}</g:link>
<g:link controller="book">Book Home</g:link>
<g:link controller="book" action="list">Book List</g:link>
<g:link url="[action:'list',controller:'book']">Book List</g:link>
<g:link action="list" params="[sort:'title',order:'asc',author:currentBook.author]">
Book List
</g:link>
GSP支持如下不同字段类型的定制: 每一个都允许GSP表达式作为值:被当作任意的正规标签或者当作方法被调用.
textField - 'text'类型输入字段
checkBox - 'checkbox'类型输入字段
radio - 'radio'类型输入字段
hiddenField - 'hidden'类型输入字段
select - 处理 HTML 选择框
处理多样的提交按钮这样由来已久的问题,同样可以通过Grails的actionSubmit标签优雅的处理。
它就像一个正规提交,但是,允许你指定一个可选的操作来提交。
在控制器和标签库中的模板
可以使用控制器render方法渲染模板控制器中,它对Ajax引用很有用。 在控制器中的render方法最普通的行为是直接写入响应。假如,
你需要获得模板作为一个String的结果作为替代,你可以使用render标签:
Grails利用了Sitemesh,一个装饰引擎,来支持视图布局。布局位于grails-app/views/layouts目录中。一个典型的布局如下:
<html>
<head>
<title><g:layoutTitle default="An example decorator" /></title>
<g:layoutHead />
</head>
<body onload="${pageProperty(name:'body.onload')}">
<div class="menu"><!--my common menu goes here--></menu>
<div class="body">
<g:layoutBody />
</div>
</div>
</body>
</html>
关键的元素是layoutHead,layoutTitle 和 layoutBody标签的用法,这里是他们所做的:
layoutTitle - 输出目标页面的title
layoutHead - 输出目标页面head标签内容
layoutBody - 输出目标页面body标签内容
早前的示例也证明了pageProperty标签能被用去检查和返回目标页面的方向。
简单的在视图中添加meta标签来启动布局:在这种情况下,一个名为grails-app/views/layouts/main.gsp 将被用于布局这个页面
<html>
<head>
<title>An Example Page</title>
<meta name="layout" content="main"></meta>
</head>
<body>This is my content!</body>
</html>
Grails标签库机制是简单的,优雅的,在运行时完全可重载的。
创建一个标签库是相当简单的,创建一个以规约TagLib结尾的一个Groovy类,并把它放置于grails-app/taglib目录里。
<g:example />
<g:example>
Hello world
</g:example>
变量可以在GSP中使用set标签来定义。
page - 当前页面范围 (默认)
request - 当前请求范围
flash - flash作用域,因此它可以在下一次请求中有效
session - 用户session范围
application - 全局范围.