您的位置:首页 > 编程语言 > Java开发

struts2标签

2016-06-01 09:28 441 查看
<s:action>:

使用action标签,可以允许在jsp页面中直接调用Action,在调用Action时候,可以指定需要被调用的Action的name和namespace.如果指定了executeResult参数的属性值为true,该标签会把Action的处理结果(视图资源)包含到本页面中. 使用action标签指定属性有:

id: 可选属性,作为该Action的引用ID

name:必选属性,指定调用Action

namespace:可选属性,指定该标签调用Action所属namespace

executeResult:可选属性,指定是否将Action的处理结果包含到本页面中.默认值为false,不包含.

ignoreContextParam:可选参数,指定该页面的请求参数是否需要传入调用的Action中,默认值是false,即传入参数.

<s:action name="login" executeResult="true" namespace="/"></s:action>

传递参数

<s:action name="actinName" executeResult="true" namespace="/">

<s:param name="currentPage" value="传递的值"></s:param>

</s:action>

<s:param ></s:param>是以request方式的值的,而不是以参数传值

所以request.getParameter("")会获取不到值

通过request.getAttribute("")方式可以获取

另外:使用<s:param ></s:param> value指代的是action定义的对象的名称,而不是一个值

和 <s:textfield>中的name是一个意思,所以要要传递字符串的不能把值写value中而应该写到

<s:param >写到这里</s:param>

If elseif else

描述:

执行基本的条件流转。

参数:
名称
必需
默认
类型
描述
备注
test

boolean
决定标志里的内容是否显示的表达式
else标志没有这个参数
id

Object/String
用来标识元素的id。在UI和表单中为HTML的id属性
Iterator(迭代)

描述:用于遍历集合(java.util.Collection)或枚举值(java.util.iterator)

参数
名称
必需
默认
类型
描述
status

String
如果设置此参数,一个IteratorStatus的实例将会压入每一个遍历的堆栈
value

Object/String
要遍历的可枚举的(iteratable)数据源,或者将放入的新列表(List)的对想
id

Object/String
用来标识元素的id。在ui和表单中为HTML的id属性
I18n(国际化操作)

描述:

加载资源包到值堆栈。它可以允许text标志访问任何资源包的信息。而不只当前的action相关联的资源包。
名称
必需
默认
类型
描述
name

Object/String
资源包的类路径(如com.xxxx.resources.AppMsg)
id

Object/String
用来标识元素的id。在ui和表单中为HTML的id属性
Include

描述:包含一个servlet的输出(servlet或jsp的页面)

<s:include value="/CMS/headers/wrap/header.jsp"/>

名称
必需
默认
类型
描述
value

String
要包含的jsp页面或servlet
id

Object/String
用来标识元素的id。在ui和表单中为HTML的id属性
param

描述:属性是可选的,如果提供,会调用Component的方法,addParameter(String,Object),如果不提供,则外层嵌套标签必须实现UnnamedParametric接口。

Value的提供有两种方式,通过value属性或者标签中间的text,不同之处:

<s:param name="name">zhaosoft</s:param> //传入的是字符串

参数会以String的格式放入statck

<s:param name="name" value="zhaosoft"/>

该值会以java.lang.Object的格式放入statck //可以放入el表达式,也即传入变量
名称
必需
默认
类型
描述
name

String
参数名
value

String
value表达式
id

Object/String
用来标识元素的id。在ui和表单中为HTML的id属性

set

描述:set标签赋予变量一个特定范围内的值。当希望给一个变量赋一个复杂的表达式,每次访问该变量而不是复杂的表达式时用到。其在两种情况下非常有用:复杂的表达式很耗时(性能提升)或者很难理解(代码的可读性提高)

参数:
名称
必需
默认
类型
描述
name

String
变量名字
scope

String
变量作用域,可以为application,session,request,page,action
value

Object/String
将会赋给变量的值
id

Object/String
用来标识元素的id。在ui和表单中为HTML的id属性

Text

描述:支持国际化信息的标签。国际化信息必须放在一个和当前action同名的resource bundle中,如果没有找到相应message,tag body将被当作默认的message,如果没有tag body,message的name会被作为默认message.需要配合<s:i18n>使用
名称
必需
默认
类型
描述
name

String
资源属性的名字
id

Object/String
用来标识元素的id。在ui和表单中为HTML的id属性

url

描述:该标签用于创建url,可以通过”param”标签提供request参数。

当includeParams的值是all或get,param标签中定义的参数将有优先权,也就是说其会覆盖其他同名参数的值。

<!--action是action的名字,为url添加参数使用param标签-->

<s:url var="urlName" action="mainPage">
<s:param name="id" value="123"/>
</s:url>

<!--使用上面定义的url-->
<s:a href="%{urlName}">测试连接</s:a>

该方法在生成的页面源码中生成如下代码
<a href="/NetBookShop_081029/mainPage?id=123">测试连接</a>

includeParams属性


UI标志

单行文本框

Textfield标签输出一个HTML单行文本输入控件,等价于HTML代码<input type=”text”>
名称
必需
默认
类型
描述
maxlength


Integer
文本输入控件可以输入字符的最大长度
readonly

false
Boolean
当该属性为true时,不能输入
size


Integer
指定可视尺寸
id

Object/String
用来标识元素的id。在ui和表单中为HTML的id属性
例子:

<s:form action="register" method="post">

<s:textfield name="username" label="用户名"></s:textfield>

</s:form>

文本框区

Textarea标签输出一个HTML多行文本输入控件,等价于HTML代码:<textarea />
名称
必需
默认
类型
描述
cols


Integer
列数
rows


Integer
行数
readonly

false
Boolean
当该属性为true时,不能输入
wrap

false
Boolean
指定多行文本输入控件是否应该换行
id

Object/String
用来标识元素的id。在ui和表单中为HTML的id属性
例子:

<s:textarea name="personal" cols="10" rows="5" label="个人简历"></s:textarea>

下拉列表

s:select 标签输出一个下拉列表框,相当于HTML代码中的<select/>
名称
必需
默认
类型
描述
list


Cellection Map Enumeration Iterator array
要迭代的集合,使用集合中的元素来设置各个选项,如果list的属性为Map则Map的key成为选项的value,Map的value会成为选项的内容
listKey


String
指定集合对象中的哪个属性作为选项的value
listValue


String
指定集合对象中的哪个属性作为选项的内容
headerKey


String
设置当用户选择了header选项时,提交的的value,如果使用该属性,不能为该属性设置空值
headerValue


String
显示在页面中header选项内容
emptyOption

false
Boolean
是否在header选项后面添加一个空选项
multiple

false
Boolean
是否多选
size


Integer
显示的选项个数
例子:

%@ page contentType="text/html;charset=GBK" %>

<%@ taglib prefix="s" uri="/struts-tags" %>

<h3>使用name和list属性,list属性的值是一个列表</h3>

<s:form>

<s:select label="最高学历" name="education" list="{'高中','大学','硕士','博士'}"/>

</s:form>

<h3>使用name和list属性,list属性的值是一个Map</h3>

<s:form>

<s:select label="最高学历" name="education" list="#{1:'高中',2:'大学',3:'硕士',4:'博士'}"/>

</s:form>

<h3>使用headerKey和headerValue属性设置header选项</h3>

<s:form>

<s:select label="最高学历" name="education" list="{'高中','大学','硕士','博士'}"

headerKey="-1" headerValue="请选择您的学历"/>

</s:form>

<h3>使用emptyOption属性在header选项后添加一个空的选项</h3>

<s:form>

<s:select label="最高学历" name="education" list="{'高中','大学','硕士','博士'}"

headerKey="-1" headerValue="请选择您的学历"

emptyOption="true"/>

</s:form>

<h3>使用multiple属性设置多选</h3>

<s:form>

<s:select label="最高学历" name="education" list="{'高中','大学','硕士','博士'}"

headerKey="-1" headerValue="请选择您的学历"

emptyOption="true"

multiple="true"/>

</s:form>

<h3>使用size属性设置下拉框可显示的选项个数</h3>

<s:form>

<s:select label="最高学历" name="education" list="{'高中','大学','硕士','博士'}"

headerKey="-1" headerValue="请选择您的学历"

emptyOption="true"

multiple="true" size="8"/>

</s:form>

<h3>使用listKey和listValue属性,利用Action实例的属性(property)来设置选项的值和选项的内容</h3>

<s:form>

<s:select label="最高学历" name="education" list="educations"

listKey="id" listValue="name"/>

</s:form

doubleselect标签

doubleselect标签输出关联的两个HTML列表框,产生联动效果。
名称
必需
默认
类型
描述
list


Cellection Map Enumeration Iterator array
要迭代的集合,使用集合中的元素来设置各个选项,如果list的属性为Map则Map的key成为选项的value,Map的value会成为选项的内容
listKey


String
指定集合对象中的哪个属性作为选项的value,该选项只对第一个列表框起作用
listValue


String
指定集合对象中的哪个属性作为选项的内容,该选项只对第一个列表框起作用
headerKey


String
设置当用户选择了header选项时,提交的的value,如果使用该属性,不能为该属性设置空值
headerValue


String
显示在页面中header选项内容
emptyOption

false
Boolean
multiple

false
Boolean
是否多选
size


Integer
显示的选项个数,该选项只对第一个列表框起作用
doubleId


String
指定第二个列表框的ID
doubleList


Cellection Map Enumeration Iterator array
要迭代的集合
doubleListKey


String
指定集合对象中的哪个属性作为选项的value,该选项只对第二个列表框起作用
doubleListValue


String
指定集合对象中的哪个属性作为选项的内容,该选项只对第二个列表框起作用
doubleSize


Integer
选项个数
doubleName


String
指定第二个列表框的name映射
doubleValue


Object
第二个列表框的初始选种项
实例:

<s:form name="test">

<s:doubleselect label="请选择所在省市"

name="province" list="{'四川省','山东省'}" doubleName="city"

doubleList="top == '四川省' ? {'成都市', '绵阳市'} : {'济南市', '青岛市'}" />

</s:form>

<s:form action="doubleselectTag">

<s:doubleselect

label="请选择所在省市"

name="province"

list="provinces"

listKey="id"

listValue="name"

doubleList="cities"

doubleListKey="id"

doubleListValue="name"

doubleName="city"

headerKey="-1"

headerValue="---------- 请选择 ----------"

emptyOption="true" />

</s:form>

复选框
名称
必需
默认
类型
描述
fieldValue

true
String
指定在复选框选中时,实际提交的值
复选框组,对应Action中的集合
名称
必需
默认
类型
描述
list


Cellection Map Enumeration Iterator array
要迭代的集合,使用集合中的元素来设置各个选项,如果list的属性为Map则Map的key成为选项的value,Map的value会成为选项的内容
listKey


String
指定集合对象中的哪个属性作为选项的value
listValue


String
指定集合对象中的哪个属性作为选项的内容
例子:checkboxlistTag.jsp

<%@ page contentType="text/html;charset=GBK" %>

<%@ taglib prefix="s" uri="/struts-tags" %>

<s:form>

<s:checkboxlist name="interest" list="{'足球','篮球','排球','游泳'}" label="兴趣爱好"/>

</s:form>

单击复选框

文件选择组建

file标签输出一个HTML文件选择框。
名称
必需
默认
类型
描述
accept

input
String
HTML accept属性,指出接受文件的MIME类型
按钮

Submit标签输出一个按钮,submit标签和form标签使用可以提供异步表单提交功能。Submit标签可以输出以下三种类型的提交按钮:

Input: 等价于 HTML代码<input type=”submit”>

Image: 等价于 HTML代码 <input type="image">

Button:<button type="submit"></button>
名称
必需
默认
类型
描述
type

input
String
要使用的提交按钮的类型,有效值:input button image
src


String
为image类型的提交按钮设置图片地址。该属性对input和button类型的提交按钮无效
action


String
指定处理提交请求的action
method


String
指定处理提交请求的action的方法
实例

实例1.<s:submit type="image" method="login" src="images/login.jpg"></s:submit>

页面输出:
<input type="image" alt="Submit" src="images/login.jpg" id="user__login" name="method:login" value="Submit"/>


实例2.<s:submit type="button" action="selectTag" method="login" label="登陆"></s:submit>

页面输出:
<button type="submit" id="user_selectTag_login" name="action:selectTag!login" value="Submit">登陆</button>


Struts2预定义的前缀:

1。method method:login

使用method前缀,来取代action默认的execute()方法的执行。

<s:form action="user">

<s:textfield name="user.username" label="用户名"></s:textfield>

<s:textfield name="user.password" label="密码"></s:textfield>

<s:submit value="登陆" name="method:login"></s:submit>

<s:submit value="注册" name="method:register"></s:submit>

</s:form>

注意:1。input类型的按钮,不能用label设置按钮上的文本,只能用value

2、action前缀

使用action前缀,取代form标签指定的action,导向到另一个action进行处理。

<s:form action="login">

<s:textfield name="user.username" label="用户名"></s:textfield>

<s:textfield name="user.password" label="密码"></s:textfield>

<s:submit value="登陆"></s:submit>

<s:submit value="注册" name="action:register"></s:submit>

</s:form>

2、redirect前缀

使用redirect前缀请求重定向到其他的url,甚至可以是web英语程序外部的url。

<s:form action="login">

<s:textfield name="user.username" label="用户名"></s:textfield>

<s:textfield name="user.password" label="密码"></s:textfield>

<s:submit value="登陆"></s:submit>

<s:submit value="搜索" name="redirect:www.google.com"></s:submit>

</s:form>

2、redirect-action前缀

使用redirect-action前缀请求重定向到其他的action.

<s:form action="login">

<s:textfield name="user.username" label="用户名"></s:textfield>

<s:textfield name="user.password" label="密码"></s:textfield>

<s:submit value="登陆"></s:submit>

<s:submit value="搜索" name="redirect-action:register"></s:submit>

</s:form>

reset标签

reset标签输出一个重置按钮
名称
必需
默认
类型
描述
type

input
String
要使用的重置按钮的内容,input、button
<s:reset value="重置"></s:reset>

<s:reset type="button" label="重置"></s:reset>

updownselect标签

updownselect标签创建一个带有上下移动的按钮的列表框,可以通过上下移动按钮来调整列表框的选项的位置。

名称
必需
默认
类型
描述
list


Cellection Map Enumeration Iterator array
要迭代的集合,使用集合中的元素来设置各个选项,如果list的属性为Map则Map的key成为选项的value,Map的value会成为选项的内容
listKey


String
指定集合对象中的哪个属性作为选项的value
listValue


String
指定集合对象中的哪个属性作为选项的内容
headerKey


String
设置当用户选择了header选项时,提交的的value,如果使用该属性,不能为该属性设置空值
headerValue


String
显示在页面中header选项内容
emptyOption

false
Boolean
是否在header选项后面添加一个空选项
multiple

false
Boolean
是否
1cbe7
多选
size


Integer
显示的选项个数
moveUplabel

String
设置向上移动按钮上的文本
moveDownLabel

String
设置向下移动按钮上的文本
selectAllLabel

String
设置向全部选择按钮上的文本
allowMoveUp


Boolean
设置是否使用向上移动按钮
allowMoveDown


Boolean
设置是否使用向下移动按钮
allowSelectAll


Boolean
设置是否使用全部选择按钮
实例:

<s:form>

<!-- 使用简单集合来生成可上下移动选项的下拉选择框 -->

<s:updownselect name="a" label="请选择您喜欢的图书" labelposition="top"

moveUpLabel="向上移动"

list="{'Spring2.0宝典' , '轻量级J2EE企业应用实战' , 'JavaScript: The Definitive Guide'}"/>

<!-- 使用简单Map对象来生成可上下移动选项的下拉选择框

且使用emptyOption="true"增加一个空选项-->

<s:updownselect name="b" label="请选择您想选择出版日期" labelposition="top"

moveDownLabel="向下移动"

list="#{'Spring2.0宝典':'2006年10月' , '轻量级J2EE企业应用实战':'2007月4月' , '基于J2EE的Ajax宝典':'2007年6月'}"

listKey="key"

emptyOption="true"

listValue="value"/>

<s:bean name="com.zhaosoft.ui.formtag.BookService" id="bs"/>

<!-- 使用集合里放多个JavaBean实例来可上下移动选项的生成下拉选择框 -->

<s:updownselect name="c" label="请选择您喜欢的图书的作者" labelposition="top"

selectAllLabel="全部选择" multiple="true"

list="#bs.books"

listKey="author"

listValue="name"/>

</s:form>

package com.zhaosoft.ui.formtag;

public class BookService

{

public Book[] getBooks()

{

return new Book[]

{

new Book("Spring2.0宝典","zhaosoft"),

new Book("轻量级J2EE企业应用实战","zhaosoft"),

new Book("基于J2EE的Ajax宝典","zhaosoft")

};

}

}

optiontransferselect标签

optiontransferselect标签创建一个选项转移列表组建,它由两个<select>标签以及它们之间的用于将选项在两个<select>之间相互移动的按钮组成。表单提交时,将提交两个列表框中选中的选项。
名称
必需
默认
类型
描述
list


Cellection Map Enumeration Iterator array
要迭代的集合,使用集合中的元素来设置各个选项,如果list的属性为Map则Map的key成为选项的value,Map的value会成为选项的内容,该选项只对第一个列表框起作用
listKey


String
指定集合对象中的哪个属性作为选项的value,该选项只对第一个列表框起作用
listValue


String
指定集合对象中的哪个属性作为选项的内容,该选项只对第一个列表框起作用
headerKey


String
设置当用户选择了header选项时,提交的的value,如果使用该属性,不能为该属性设置空值
headerValue


String
显示在页面中header选项内容
multiple

false
Boolean
是否多选
size


Integer
显示的选项个数,该选项只对第一个列表框起作用
doubleId


String
指定第二个列表框的ID
doubleList


Cellection Map Enumeration Iterator array
要迭代的集合,使用集合中的元素来设置各个选项,如果doubleList的属性为Map则Map的key成为选项的value,Map的value会成为选项的内容,该选项只对第二个列表框起作用
doubleListKey


String
指定集合对象中的哪个属性作为选项的value,该选项只对第二个列表框起作用
doubleListValue


String
指定集合对象中的哪个属性作为选项的内容,该选项只对第二个列表框起作用
doubleHeaderKey


String
设置当用户选择了header选项时,提交的的value,如果使用该属性,不能为该属性设置空值
doubleHeaderVale


String
显示在页面中header选项内容
doubleEmptyOption


String
是否在第二列表框的header后面添加一个空选项
doubleMultiple

true
Boolean
是否多选
doubleSize


Integer
选项个数
doubleName


String
指定第二个列表框的name映射
doubleValue


Object
第二个列表框的初始选种项
leftTitle


String
左边列表框的标题
rightTitle

<-
String
右边列表框的标题
addToLeftLable

String
addToRightLable
addAllToLeftLable
addAllToRightLable
leftUpLabel
leftDownLabel
rightUpLabel
rightDownLabel
allowAddToLeft
allowAddToright
allowAddAllToLeft
allowAddAllToRight
allowSelectAll


Boolean
设置是否使用全部选择按钮
allowUpdownOnLeft
allowUpDownOnRight
例子:

<s:head/>

<s:form>

<s:optiontransferselect

label="最喜爱的图书"

name="javaBook"

list="{'《Java Web开发详解》', '《Struts 2深入详解》', '《Java快速入门》'}"

doubleName="cBook"

doubleList="{'《VC++深入详解》', '《C++ Primer》', '《C++程序设计语言》'}"/>

</s:form>

---------------------------

<s:form>

<s:optiontransferselect

label="最喜爱的图书"

name="book1"

leftTitle="Java图书"

rightTitle="C/C++图书"

list="{'《Java Web开发详解》', '《Struts 2深入详解》', '《Java快速入门》'}"

headerKey="-1"

headerValue="--- 请选择 ---"

emptyOption="true"

doubleName="book2"

doubleList="{'《VC++深入详解》', '《C++ Primer》', '《C++程序设计语言》'}"

doubleHeaderKey="-1"

doubleHeaderValue="--- 请选择 ---"

doubleEmptyOption="true"

addToLeftLabel="向左移动"

addToRightLabel="向右移动"

addAllToLeftLabel="全部左移"

addAllToRightLabel="全部右移"

selectAllLabel="全部选择"

leftUpLabel="向上移动"

leftDownLabel="向下移动"

rightUpLabel="向上移动"

rightDownLabel="向下移动"/>

</s:form>
具体参考:http://www.360doc.com/content/13/1105/23/7669533_327022413.shtml
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: