a标签创建一个HTML超链接,等价于HTML 的<a href=""....
示范代码:
<s:a href="login.action">登陆</s:a>
使用action标签 可以允许在JSP页面中直接调用Action。
范例如下:
<s: action name="tag2" executeResult="false" />
这个标签负责输出错误信息到客户端。
示范代码:Action代码如下:
public String execute() { addActionError("第一条错误消息!"); addActionError("第二条错误消息!");return SUCCESS;
}.... JSP中:<s:actionerror/>Action代码如下:
public String execute() { addActionMessage("第一条普通消息!"); addActionMessage("第二条普通消息!"); return SUCCESS; } JSP:<s:actionmessage />用来做iterator标签的辅助,将不同iterator中的内容合在一个iterator中。
例子: <s:append id="myAppendIterator"> <s:param value="%{myList1}" /> <s:param value="%{myList2}" /> <s:param value="%{myList3}" /> </s:append> <s:iterator value="%{#myAppendIterator}"> <s:property /> </s:iterator>bean标签 用于创建一个JavaBean的实例。
示范样例:
<s:bean name="lee.Person" id=“p”>
<!--使用Param标签为lee。Person类的实例传入参数--> <s:param name="name" value="'yeeku'"/> <s:param name="age" value="29"/> </s:bean>checkbox标签输出一个HTML复选框,等价于HTML代码:<input type="checkbox" .../>。
示范代码:
<s:checkbox label="性别" name="user.sex" value="true" fieldValue="dddd"/>
标签输出一个复选框。
示范代码:
<s:form> <s:checkboxlist name="interest" list="{'足球','篮球','排球','游泳'}" label="兴趣爱好"/></s:form>combobox标签生成一个单行文本框和下拉列表框的结合。
示范代码:
<s:combobox label="请选择您喜欢的图书" theme="css_xhtml" labelposition="top" list="{'Spring2.0' , 'J2EE' , 'Ajax'}" size="20" maxlength="20" name="book"/>
conponent标签用于使用自定义标签。因为使用自定义组件还是基于主题,模板管理的,因此在使用component标签,常常需要指定如下3个属性:
theme:自定义组件所使用的主题,默认使用xhtml主题。 templateDir:指定自定义组件的主题目录,默认使用系统的主题目录,即template目录。 template:指定自定义组件所使用的模板。
示范代码:
<s:component template="mytemplate.jsp"> <s:param name="list" value="{'Spring2.0' , 'J2EE' , 'Ajax'}" /> </s:component>date标签 用于格式化输入一个日期,还可以计算指定日期和当前时刻之间的时差。
示范代码:<s:date name="#attr.now" format="dd/MM/yyyy" nice=“true”/>
datetimepicker标签就是生成一个有日期控件的文本输入框。它有一个前提就是要在<head></head>内加一个"<s:head theme="ajax" />",然后可以在form内加上该标签。
示范代码:
<s:datetimepicker name="user.birthday" label="出生日期" value="%{'2008-9-20'}"/>
debug标签主要用于辅助测试,它在页面上生成一个超链接,通过该链接可以查看ValueStack和Stack Context 中的所有值信息。
使用debug标签只有一个id属性,这个属性仅仅是该元素一个引用id。
在页面上增加<s:debug/>标签,通过debug标签,可以看的系统中ValueStack离得全部信息,并可以看到Stack Context中的属性。
<s:debug></s:debug>
//直接在jsp页面上面添加这样的标签,就可以生产一个查看debug信息的链接 示范代码:else标签用来控制基本的条件处理流程,通常和if、elseif标签连用。
例子
<s:if test="%{false}"> <div>Will Not Be Executed</div> </s:if> <s:elseif test="%{true}"> <div>Will Be Executed</div> </s:elseif> <s:else> <div>Will Not Be Executed</div> </s:else>elseif标签用来控制基本的条件处理流程,通常和if标签连用。
例子
<s:if test="%{false}">
...</s:if>
<s:elseif test="%{true}">
<div>Will Be Executed</div>
</s:elseif>
<s:else>
...</s:else>
fielderror标签输出action的fieldErrors属性保存的字段错误,fieldErrors是一个map类型的属性。
示范代码:
<s:fielderror/>
file标签输出一个HTML文件选择框,等价于html代码:<input type="file" .../>。
示范代码:
<s:file name="uploadfile" accept="text/*" /> <s:file name="uploadfile" accept="text/html,text/plain" />
例子:
<s:form action="exampleSubmit" method="post" enctype="multipart/form-data">
<s:submit /> <s:reset /> </s:form>可以上传文件的form。
使用generator标签可以将指定字符串按指定分隔符分成多个子串,临时生成的多个子串可以使用iterator标签来迭代输出。可以这样理解:generator将一个字符串转化成一个集合。在该标签的标签体内,整个临时生成的集合将位于ValueStack的顶端,蛋一旦该标签结束,该集合将被移出ValueStack。
head标签主要用于成生HTML主要页面的HEAD部分。国为有些主题需要包含特定的CSS和javascript代码,而该标签则用于生成对这此CSS和javaScript代码的引用。
示范代码:
<head><title>page 1</title><s:head/></head>
hidden标签输出一个HTML隐藏表单元素,等价于HTML代码:<input type="hidden" .../>。
在xhtml主题下,hidden标签与其他的标签不一样,hidden标签并不输出表行。xhtml主题直接从simple主题继承了
hidden.ftl模板。
示范代码:
<s:hidden name="id" value="s"/>
该标签用于加载资源包到值堆栈。它可以允许text标志访问任何资源包的信息,而不只当前action相关联的资源包。
示范代码:
<s:i18n name="ApplicationMessages">
<s:text name="HelloWorld" /> </s:i18n>If标签用来控制基本的条件处理流程,通常和else标签或者elseif标签连用。
例子:
<s:if test="%{false}">
<div>Will Not Be Executed</div>
</s:if>
include标签 用于将一个JSP页面,或者一个Servlet包含到本页面中。
示范代码:
<h2>使用s:include标签来包含目标页面</h2>
<s:include value="include-file.jsp"/>
<!--使用include标签来包含其他页面,并且传入参数-->
<s:include value="include-file.jsp">
<s:param name="author" value="'yeeku'" />
</s:include>
迭代处理一个java.util.Connection或者java.util.Iterator对象
例子:
<s:iterator value="users" status="userStatus">
<s:property value="fullName" /> <s:if test="!#userStatus.last">,</s:if> </s:iterator>
xhtml主题下的label 标签输出两个 HTML的label标签(simple主题下的label标签只输出一个HTML label标签)。分别位于一行的两列,左列的label标签器提示作用,右列的label标签用于显示只读的action属性数据。
示范代码:
<s:label label="用户名" name="user.username"/>
合并遍历集合出来的值,与<s:append>标签用法相似。
例子:
<s:merge id="list">
<s:param value="#request.list1"/> <s:param value="#request.list2"/> <s:param value="#request.list3"/> <s:param value="#request.list4"/> </s:merge> <s:iterator value="%{list}"> <s:property/><br> </s:iterator>optgroup标签用于生成一个下拉列表框的选项组,因此,该标签必须放在<s:select>标签中使用,一个下拉列表框中可以包含多个选项组,因此可以在一个<s:select>标签中使用多个<s:optgroup>标签。
<s:select label="选择您喜欢的图书" name="book" list="#{'Spring2.0':'李刚','J2EE':'李','Ajax宝典':'李'}"
listKey="value" listValue="key"> <s:optgroup label="Rod Johnson" list="#{'Expert One-on-One J2EE Design and Development':'Johnson'}" listKey="value" listValue="key"/> <s:optgroup label="David Flanagan" list="#{'JavaScript: The Definitive Guide':'David'}" listKey="value" listValue="key"/> </s:select>param标签 主要用于为其他标签提供参数
用法:
<param name="color" value="blue" /> 这里color参数的值是,blue对象的值----如果blue对象不存在,则color为null。<s:password>标签类同于HTML的<input type=”password” …>,其name和label类同于<s:textfield>
例子:
<s:password name="password" label="密码"/>
例子:
<s:property value="username" default="游客"/>
取出栈顶对象(通常是action)的username 属性并输出,如果没有找到username属性,那么输出“游客”。
push标签用于将某个值放到ValueStack的栈顶,可以跟简单的访问该值。
示范样例: <s:bean name="lee.Person" id="p"> <s:param name="age" value="29"/> </s:bean> <s:push value="#p"> <s:property value="name"/> <s:propery value="age"/> </s:push>radio标签的用法与checkboxlist的用法几乎完全相同,一样可以指定label, list, listKey, listValue等属性。
示范代码:
<s:radio name="c" label="请选择您喜欢的图书" labelposition="top" list="#bs.books" listKey="author" listValue="name"/><s:reset type="button" label="重置"></s:reset>
s:select 标签输出一个下拉列表框,相当于HTML代码中的<select/>
示范代码:
<s:form> <s:select label="最高学历" name="education" list="{'高中','大学','硕士','博士'}"/> </s:form>set标签是将某个值放到指定范围内, 比如说 student.teacher.parent.age 每次访问这个属性不仅性能低,而且代码可读性很差,为了解决这个问题,可以将这个值设置为一个新值,并且放入指定范围内。
使用示范: <s:set value="#p" name="test"/> <s:property value="#test.name"/> <br> <s:property value="#test.age"/> <br>
对一个可以迭代的对象进行排序操作。
<s:sort comparator="myComparator" source="myList">
<s:iterator> <!-- do something with each sorted elements --> <s:property value="..." /> </s:iterator> </s:sort>递归iterator的一部分。
例子:<s:subset source="myList">
<s:iterator>
<s:property />
</s:iterator>
</s:subset>
示范代码:
<s:i18n name="ApplicationMessages">
<s:text name="HelloWorld" /> </s:i18n>Textfield标签输出一个HTML单行文本输入控件,等价于HTML代码<input type="text">
示范代码:<s:form action="register" method="post"> <s:textfield name="username" label="用户名"></s:textfield></s:form>
token标签是用于防止多次提交的标签。避免了刷新页面时多次提交,如果需要该标签起作用,则应该在Struts2的配置文件中启用TokenInterceptor拦截器或TokenSessionStoreInterceptor拦截器。
示范代码:
<s:form> <s:token/> </s:form>
tree和treenode标签可以在页面生成一个树形结构,其中tree生成一个树形结构,treenode生成一个树节点。
示范代码:<s:tree label="图书" id="book" theme="ajax"
showRootGrid="true" showGrid="true" treeSelectedTopic="treeSelected"> <s:treenode theme="ajax" label="David" id="David"> <s:treenode theme="ajax" label="JavaScript: The Definitive Guide" id="javascript"/> </s:treenode></s:tree>tree和treenode标签可以在页面生成一个树形结构,其中tree生成一个树形结构,treenode生成一个树节点。
示范代码:<s:tree label="图书" id="book" theme="ajax"
showRootGrid="true" showGrid="true" treeSelectedTopic="treeSelected"> <s:treenode theme="ajax" label="David" id="David"> <s:treenode theme="ajax" label="JavaScript: The Definitive Guide" id="javascript"/> </s:treenode> </s:tree>示范代码:
指定action属性,且使用param传入参数的形式
<s:url action="showbook"> <s:param name="author" value="'yeeku'"> </s:url>