Jakarta Struts 编程:使用Tiles框架

 

发布时间:2006.03.15 19:55     来源:Matrix    作者:javaduke

作者:        Chuck Cavaness
原文:        http://www.onjava.com/pub/a/onjava/excerpt/progjakstruts_14/index3.html
译者:        blasterboy
        Email: [email protected]
        MSN: [email protected]

这是Jakarta Struts编程一书中使用 Tiles框架系列的第三部分,主要阐述了如何使用标记库(包括:insert, definition, put, putList, add, get, getAsString, useAttribute, importAttribute, and initComponentDefinitions).

Tiles标记库(The Tiles Tag Library)
这一部分介绍Tiles 框架使用的JSP自定义标记。表14-1列出了框架可用的标记 。这些标记与其他一些基于模板的框架所提供的标记是非常相似的,但是Tiles框架中蕴含着更丰富的功能。


表 14-1: Tiles框架标记库中的标记

标记名(Tag name)                             描述(Description)
Add                 增加一个元素到环境列表中。
definition                 创建一个Tiles组件定义。
Get                 从请求作用域中得到内容(content),这个内容是put 标
                 记所置入的。
GetAsString       传递tile/component/template属性指定的值到当前的
                 JspWriter中。
importAttribute  引入一个Tiles属性到指定的上下文(context)中;
initComponentDefinitions   初始化一个Tiles定义工厂。
Insert                   插入一个Tiles组件。
Put                   设置一个属性到一个Tiles上下文中。
PutList                    声明一个列表,这个列表作为一个属性被传递。
useAttribute        在页面中使用一个属性值。

insert 标记
      insert 标记是负责页面中插入内容。在一个Tiles布局中, insert标记使用属性值指定的内容。在非Tile布局中,insert标记是用来获得一个框架(layout)并且使用put 标记把内容传递给布局中。
表14-2列出insert 标记的属性:

表 14-2:insert 标记的属性

属性名(Attribute name)                  描述(Description)
attribute                  当前Tiles /组件上下文的属性名称,这个属性值是由
                 name 属性来传递的。
beanName        Bean 的名称作为值来使用.Bean是从指定的内容中获得。
                 如果有的话,Bean可以从指定的上下文中获得。否则就得
                 使用pageContext.findAttribute( ) 方法获得。 如果
                 beanProperty 属性已经指定,也可以从相应Bean属性中
                 获得这个值 。
                 如果,这个Bean(或Bean的属性值)是某个属性类
                 (Direct, Instance,等等)的实例, 那么插入过程要依照类
                 的类型而定。另外,调用Bean 的toString( ) 方法,并返
                 回值为String,并传给name属性。
beanProperty    Bean 属性(property)的名字,如果指定,那么这个值从
                 Bean的属性(property)中获得.
beanScope        Bean的作用范围,如果没有指定,
                 pageContext.findAttribute( ) 方法可以使用。Bean的
                 范围可以是任何的JSP, 组件(component),或者模板
                 (template)。在后两者情况(组件,模板),bean 可
                 以在 Tiles (tile)/组件(component)/模板(template)
                 内容中
component        一个描述tile 或者 模板(template)URI的字符串. 模板
                 (template),页(page)和 组件(component)属
                 性必须有严格相同的行为
controllerUrl      在页被插入前,控制器(controller)的直接URI 。 这个URI
                         通常用来指示一个struct action. 这个控制器(action) 是用
                来为inserted tile 准备数据的。
                只能有 一个controllerUrl 或 controllerClass
controllerClass 页面(page)被插入前,直接调用的一种控制(control)类
                的类型。这个类是用来为inserted tile 准备数据的。
                只能有 一个controllerUrl 或 controllerClass 。这个类
                实现或扩展下列类之一:
                        org.apache.struts.tiles.Controller,
                        org.apache.struts.tiles.ControllerSupport,
                        或org.apache.struts.action.Action.
definition                Insert定义的名称。定义在一个集中的文件中被定义。现
                在,仅仅一个工厂(factory)的定义可以用这个属性插入。
                插入一个用definition定义的定义,用beanName="".
flush                true 或者 false. 如果true, 当前页会在tile insertion.前
                输出流
ignore                如果这个属性设置为 true 并且name所指定的属性不存在的
                话,仅仅会返回一个什么都没有写得结果。初始值设置为
                false,可以抛出一个 runtime exception
name               一个要被插入得实体(entity)的名字。查找按照下面的顺
               序 definition, attribute, 然后 page.
page               一个表示tile 或者 template 的URI字符串。template,
                       page, 和 component 属性要严格的有同样的行为
role               如果用户是指定的角色,那么这个标记才会起作用,否则,
               这个标记会被忽略掉,并且不会写出任何内容。
template              一个表示tile 或者 template 的URI字符串。template,
                      page, 和 component 属性要严格的有同样的行为

definition 标签
    definition 标签用bean的定义方法创建一个tile (template),这个新创建的bean在requested scope用一个id来标识。definition 标签的有些语法和insert 一样。新的定义可以扩展在definition factory (XML file)中已经描述过的定义,并且可以重载以前定义的参数。

Table 14-3 列出了definition 标签支持的属性

属性名            描述
extends        可以用来扩展的父定义,这个父定义在definitions factory被
           定义了。
id        定义bean的名称,这个属性是必需的
page        要插入template/component 的URL 。和template.一样。
role        在插入一个定义前,进行检查role.如果当前用户并没有定义这个
           role,那么这个定义将不会被插入。再插入的时候进行检查,
           而不是在定义的时候。
scope        在新定义bean 的时候被创建。如果没有指定,
           默认值是page scope.
template        tile/component/template (a JSP page)的URL  .
下面的片断展示了如何在JSP中使用definition标签。

<tiles:definition   id="storefront.default"   page="/layouts/storefrontDefaultLayout.jsp"   scope="request">    <tiles:put name="header" value="/common/header.jsp" />    <tiles:put name="menubar" value="/common/menubar.jsp" />    <tiles:put name="copyright" value="/common/copyright.jsp" />  </tiles:definition>

一个完整的例子将在这章后面的"Declaring Definitions in a JSP Page" 中展示

put 标签
    put 标签用来传递属性到一个tile 组件。 这个标签只能在insert 或 definition 标签内部使用。 put标签的值被value 属性或者标签体指定。也经常被指定值得类型。
string: 文如其名
page 或template: 内容包含指定的URL. 名字通常以URL用.
definition: 内容从指定(from factory)的定义获得. 名字以已定义的名字使用。如果type 已经使用, 他就会被get 或 insert 标签插入到tile. 如果type 属性没有被指定,则内容是不确定的untyped,除非它来自一个typed bean.
提示: Setting direct="true" 与setting type="string" 是相同的.

Table 14-4 列出了put 标签的属性。

属性名                描述
beanName        Bean 的名称,和值(value)的使用方法一样.Bean是从
                 特殊的内容中获得。如果有的话,还可以用
                 pageContext.findAttribute( ) 方法获得。 如果
                 beanProperty 属性已经指定,可以从相应Bean属性中获
                 得这个值 。
beanProperty    Bean 属性(property)的名字,如果指定,那么这个值从
                 Bean的属性(property)中获得.
beanScope        Bean的作用范围,如果没有指定,
                 pageContext.findAttribute( ) 方法可以使用。Bean的
                 范围可以是任何的JSP, 组件(component),或者模板
                (template)。在后两者情况(组件,模板),bean 可以
                在 Tiles (tile)/组件(component)/模板(template) 内
                容中
content                Content 在tile 范围内。 属性相当于value 属性,增加是
                为了于JSP template tags 兼容。.
Direct                Content的控制方法: true意味着Content直接显示; false
                        意味着content 被包含。 false 是默认值。也是指定
                content 类型的一种方法。如果 direct="true", content
                        是 "string"; 如果 direct="false", content 是 "page".
                        增加这个属性是为了于JSP template tags 兼容。.
Name                属性的名称(name).
Role                如果用户是指定的角色,那么这个标记才会起作用,否则,
                这个标记会被忽略掉,并且不会写出任何内容。
Type                content 的类型(type)。有效值
                是"string", "page", "template", 或 "definition".
Value                属性的值,可以是String 或者 Object. 值是直接被分配
                的。 (value="aValue") 或者从一个bean 获得。一个
                value, content, 或 beanName 一定存在。
putList 标签
     putList 标签建立一个list,在 tile 中以值传递。 list 元素用add 标签增加。这个标签只能在insert 或definition 标签中使用。

Table 14-5 列出putList 标签的属性。

属性名        描述
Name        List 的名称。这个属性是被要求的。

add 标签
     add 标签是增加一个element 到周围的list 中。这个标签只能在putList 标签中使用。这个值可以直接被分配。 (value="aValue") 或者从一个bean中获得。 一个value 或beanName 必须被指定。

Table 14-6 列出 add 标签的属性。

属性名                   描述
beanName              Bean 的名称,和值(value)的使用方法一样.Bean
                               是从特殊的内容中获得。如果有的话,还可以用
                     pageContext.findAttribute( ) 方法获得。 如果
                     beanProperty 属性已经指定,可以从相应Bean属性
                     中获得这个值 。
beanProperty        Bean 属性(property)的名字,如果指定,那么这
                     个值从Bean的属性(property)中获得.
beanScope        Bean的作用范围,如果没有指定,
                     pageContext.findAttribute( ) 方法可以使用。
                     Bean的范围可以是任何的JSP, 组件
                     (component),或者模板(template)。在后两者
                     情况(组件,模板),bean 可以在 Tiles (tile)/组件
                     (component)/模板(template) 内容中content
                               和value 属性相同。增加这个属性是为了于JSP
                               template tags 兼容。
direct                       Content的控制方法: true意味着Content直接显示;
                              false 意味着content 被包含。 false 是默认值
role                      如果用户是指定的角色,那么这个标记才会起作用,否
                    则,这个标记会被忽略掉,并且不会写出任何内容。如果
                    add 标签在定义中被定义,则role不会起什么作用。.
type                      content 的类型(type)。有效值
                    是"string", "page", "template", 或 "definition".
                              如果type 属性没有指定,则 content 是没有类型的
                    (untyped)除非它从一个bean 类型中获得。.
value                      增加的值。可以是String 或者 Object.

get 标签
      get 标签是从 tile 文中获得内容。并且把它插入到页面中。

Table 14-7 列出get 标签的属性。

属性名        描述
flush        true 或者 false. 如果true, 当前页会在tile insertion.前输出流.
ignore        如果这个属性值被设置为 true 并且属性被指定的名字不存在,
           只会简单的返回一个什么都没有的结果。默认值是false, 它可以引
           起一个runtime exception 的抛出。
name        从 tile 范围内得到的内容的名称。这个属性是要求的。
role        如果用户是指定的角色,那么这个标记才会起作用,否则,这个标
           记会被忽略掉,并且不会写出任何内容。

getAsString 标签
     getAsString标记负责查找tile属性指定的属性值,并作为字符串传给当前的JspWriter对象,一般使用toString()方法进行转换。如果不存在,将会抛出一个JSPException异常。表14-8列出了这个标记的属性:

Table 14-8: getAsString标记属性

属性名        描述
ignore        如果这个属性值被设置为 true 并且属性被指定的名字不存在,只
           会简单的返回一个什么都没有的结果。默认值是false, 它可以引起
           一个runtime exception 的抛出。
name        属性的名称(name). 这个属性是要求的
role        如果用户是指定的角色,那么这个标记才会起作用,否则,这个标
          记会被忽略掉,并且不会写出任何内容。

useAttribute标记
    useAttribute 标记在指定的范围内使用tile的属性值声明了一个Java 变量和一个属性。这个变量和属性由id指定一个名字,如果没有指定,则是original name 。

Table 14-9 列出了useAttribute tag的属性。

属性名             描述
classname       声明变量的类名
id                属性和变量所声明的名称
ignore                如果这个属性值被设置为 true 并且属性被指定的名字不存
                在,只会简单的返回一个什么都没有的结果。默认值是
                false, 它可以引起一个runtime exception 的抛出。
name                属性的名称(name). 这个属性是要求的
scope                声明属性的Scope.默认是"page".

importAttribute标记

    importAttribute 标记从tile 中插入一个属性到被请求的作用域。name 和 scope 属性是可选的。如果没有指定,所有的属性将引入到page作用域 中. 一旦引入,这个属性可以像其他在JSP中的BEAN一样使用。
Table 14-10 列出了 importAttribute 标签的属性

Table 14-10: importAttribute标记属性

属性名        描述
ignore        如果这个属性值被设置为 true 并且属性被指定的名字不存在,只
           会简单的返回一个什么都没有的结果。默认值是false, 它可以引起
           一个runtime exception 的抛出。
name        Tile的属性名。如果没有指定,则所有的属性将被引入。
scope        被引入属性的scope属性,默认值"page".
initComponentDefinitions标记
      initComponentDefinitions标记初始化定义工厂。

Table 14-11: initComponentDefinitions标记的属性

属性名           描述
classname    如果指定,值为创建和初始化工厂属性的类名。
file             定义文件名,此属性是必需的


你可能感兴趣的:(编程,bean,jsp,框架,struts)