Gsp

Gsp,第1张

Gsp

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 - 全局范围.

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/588560.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-04-12
下一篇 2022-04-12

发表评论

登录后才能评论

评论列表(0条)

保存