Struts标记库-LOGIC标记库

<logic:iterate>

<logic:iterate>标记用于在页面中创建一个循环,以此来遍历如数组,Collection,Map这样的对象。该标记的功能强大,在Struts应用的页面中经常使用到。

 

<logic:iterate id="array1" name="test1"length="3" offset="0" indexId="number">
<bean:write name="number"/>:
<bean:write name="array1"/>
</logic:iterate>

name属性用于指定某一存在的对象

id属性定义一个新的对象来引用name 属性所指定的对象

offset属性指定了从第几个元素开始输出

length属性指定了输出元素的个数

indexId属性,它指定一个变量存放当前集合中正被访问的元素的序号

 

<%
    HashMapcountries = new HashMap();
    countries.put("country1","中国");
    countries.put("country2","美国");
    countries.put("country3","英国");
    countries.put("country4","法国");
    countries.put("country5","德国");
    pageContext.setAttribute("countries",countries);
%>
<logic:iterate id="country"name="countries">
<bean:write name="country"property="key"/>: <bean:writename="country" property="value"/>
</logic:iterate>

上面的代码首先定义了一个HashMap的对象,并向其中添加了5个元素,再把它存入pageContext对象中,命名为countries。令<logic:iterate>标记的name属性等于"countries",id为country。再让<bean:write>标记的name属性和<logic:iterate>标记的id属性相对应,令property一个为"key",一个为"value"。便会有以下输出结果:

country5: 德国
country3: 英国
country2: 美国
country4: 法国
country1: 中国

从效果上看出,<logic:iterate>标记确定遍历了HashMap的每一个元素,但它并未按添加的顺序将其显示出来。这是因为HashMap是无序存放的。

 

对List进行循环遍历

logic:iterate>标记也可以对List型的对象进行遍历,以下是一段示例代码。<%
ArrayList list1 = new ArrayList();
list1.add("str1");
list1.add("str2");
list1.add("str3");
list1.add("str4");
list1.add("str5");
pageContext.setAttribute("testlist",list1);
%>
<logic:iterate id="showlist" name="testlist"indexId="index">
<bean:write name="index"/>:
<bean:write name="showlist"/>
</logic:iterate>

运行效果如下:

0: str1
1: str2
2: str3
3: str4
4: str5

嵌套遍历

<logic:iterate>标记还可以进行嵌套遍历,以下是一段代码示例:

<%
String [] colors = {"red","green","blue"};
String [] countries1 = {"中国","美国","法国"};
String [] persons = {"乔丹","布什","克林顿"};
ArrayList list2 = new ArrayList();
list2.add(colors);
list2.add(countries1);
list2.add(persons);
pageContext.setAttribute("list2",list2);
%>
<logic:iterate id="first" name="list2"indexId="numberfirst">
     <bean:writename="numberfirst"/>:
     <logic:iterateid="second" name="first">
         <bean:writename="second"/>
     </logic:iterate>
     <br>
</logic:iterate>

上面的代码使用了双重循环来遍历一个ArrayList对象,这个ArrayList对象内的每一个元素又是一个String型的数组。以下是运行效果:

0: red green blue
1: 中国 美国 法国
2: 乔丹 布什 克林顿

 

Logic比较标记

在Logic标记库中有以下六个比较标记:

  • <logic:equal>:判断变量是否与指定的常量相等。
  • <logic:notEqual>:判断变量是否与指定的常量不相等。
  • <logic:greaterThan>:判断变量是否大于指定的常量。
  • <logic:greaterEqual>:判断变量是否大于等于指定的常量。
  • <logic:lessThan>:判断变量是否小于指定的常量。
  • <logic:lessEqual>:判断变量是否小于等于指定的常量。

从标记的名称中可以看出它们各自的功能。以下是一个简单的程序

<%
    pageContext.setAttribute("test1",newInteger(10000));
%>
<logic:equal name="test1"value="10000">
变量test1等于10000。
</logic:equal>

运行效果如下所示:变量test1等于10000。

 

header属性:它的值表示HTTP请求中的header信息,以下是一个使用header的例子。

<logic:equal header="host"value="localhost:8080">
主机地址为localhost:8080
</logic:equal>

上面的代码从HTTP请求中读出host信息,与value属性所指定的值进行比较,当相同时同输出"主机地址为localhost:8080"的信息。下面是运行效果:

主机地址为localhost:8080

 

parameter属性:它的值表示HTTP请求中的请求参数名,以下是一个使用parameter参数的例子。

<html:linkpage="/logic-compare.jsp?testInt=12345">添加参数</html:link>
<logic:greaterThan parameter="testInt"value="10000">
参数testInt的值比10000大。
</logic:greaterThan>

 

name属性:该属性指定一个已经存在于某范围内的变量和value属性所指定的值进行比较。以下是一个例子:

<%
pageContext.setAttribute("test2","aaaab");
%>
<logic:lessThan name="test2"value="aaaac">
字符串"aaaab"比"aaaac"小。
</logic:lessThan>

上面的代码首先在pageContext对象内存入一个字符串"aaaab",并命名为test2。然后使用name属性指定该变量,并将它与字符串"aaaac"进行比较,如果比它小,则输出相应字符串。以下是运行效果:

字符串"aaaab"比"aaaac"小。

 

这里有一点值得注意,就是当相比较的两个字符串都可以转化为数字时,则按数字的大小来比较,当无法转成数字时,才按字符串进行比较。以下是一个例子

<%
    pageContext.setAttribute("a1","10000");
%>
<logic:greaterThan name="a1"value="9999.00">
10000比9999.00大
</logic:greaterThan>

<logic:lessThan name="a1"value="9999.00t">
"10000"比"9999.00t"小
</logic:greaterThan>

上面的代码将一个字符串"10000"存入pageContext对象中,然后将其先后与"9999.00"和"9999.00t"两个字符串作比较。可以看出当"10000"与"9999.00"作比较时是将之做为数字来进行的,而与"9999.00t"比较时,因为无法将其转成数字,则按字符串比较。以下是运行效果:

10000比9999.00大
"10000"比"9999.00t"小

 

Match标记

Match标记共有两个:

  • <logic:match>:判断变量中是否包含指定的常量字符串。
  • <logic:notMatch>:判断变量中是否不包含指定的常量字符串。

Match标记的功能有些类似于java.lang.String类中的indexOf方法。以下是一个简单的例子:

<%
    pageContext.setAttribute("test","Hello,World");
%>
<logic:match name="test"value="Hello">
<bean:write name="test"/>
</logic:match>

上面的代码首先在pageContext内存入一个字符串对象"Hello,World",并将其命名为test。接下来使用<logit:match>标记的value属性指定一个子串"Hello",来判断它是否被包含在test字符串中。如果被包含,则显示出test字符串的内容。很显然,结果为真。运行结果如下所示:

Hello,World

 

location属性

location属性所能取的值只有两个,一个是"start",另一个是"end"。

 是否与字符串开头或结尾

例如有以下代码示例:

<logic:notMatchname="test" value="Hello" location="end">
<bean:write name="test"/>
</logic:notMatch>

上面的<logic:notMatch>标记中使用了location属性,它的整句意思是判断test字符串是否是以"Hello"字符串结尾的,如果是则返回false,如果不是,则返回true。倘若将<logic:notMatch>标记改为<logic:match>标记,把location属性的值改为start则此时的意思就成了判断test字符串是否是以"Hello"字符串开始的,如果是则返回true,如果不是,则返回true。这就有点类似于java.lang.String类中的startWith()方法和endWith()方法。以下是运行结果:

Hello,World

Presence标记

Presence标记包括以下四个:

<logic:present>

<logic:notpresent>

<logic:messagesPresent>

<logic:messagesNotPresent>

 

<logic:present><logic:notpresent>

它们的功能是用于判断所指定的对象是否存在。例如有以下代码示例:

<%
    pageContext.setAttribute("ExistingString","teststring");
%>
<logic:present name="ExistingString"scope="pageContext">
ExistingString的值为<bean:writename="ExistingString"/>
</logic:present>

上面的代码首先向pageContext对象中存入一个字符串对象,并命名为ExistingString。然后使用<logic:present>标记来判断是否存在"ExistingString"这个变量。如果存在,就将ExistingString变量的值输出。以下是运行效果:

 

ExistingString的值为teststring

header属性:判断是否存在header属性所指定的header信息。

parameter属性:判断是否存在parameter属性指定的请求参数。

cookie属性:判断cookie属性所指定的同名cookie对象是否存在。

name属性:判断name属性所指定的变量是否存在。

property属性:和name属性同时使用,当name属性所指定的变量是一个JavaBean时,判断property属性所指定的对象属性是否存在。

 

<%
    TestPageBeantestbean = new TestPageBean("name of testbean","value");
    pageContext.setAttribute("test",testbean);
%>
<logic:notPresent name="test"property="title">
<bean:write name="test"property="name"/>
</logic:notPresent>

上面的代码首先创建了一个TestPageBean的对象,并将该对象存入pageContext对象中,命名为test。接下来,使用<logic:notPresent>标记来判断test对象是否有一个属性叫title。如果有,则返回false,如没有,则返回true,并将test对象的name属性显示出来。由于TestPageBean对象只有两个属性,一个是name,一个是value。所以,title属性并不存在。运行效果如下所示:

name of testbean

 

<messagePresent>标记和<messageNotPresent>标记。这两个标记是来判断是否在request内存在特定的ActionMessages或ActionErrors对象。它们有几个常用的属性:

name属性:指定了ActionMessages在request对象内存储时的key值。

message属性:message属性有两种取值。当其为true时,表示使用Globals.MESSAGE_KEY做为从request对象中获取ActionMessages的key值,此时无论name指定什么都无效;当其为false时,则表示需要根据name属性所指定的值做为从request对象中获取ActionMessages的key值,倘若此时未设置name属性的值,则使用默认的Globals.ERROR_KEY。

property属性:指定ActionMessages对象中某条特定消息的key值。

以下是一段代码示例:

<%
    ActionMessagesmessages = new ActionMessages();
    messages.add("message1",newActionMessage("html.errors.error1"));
    request.setAttribute(Globals.MESSAGE_KEY,messages);
%>
<logic:messagesPresent message="true"property="message1">
所查找的ActionMessage存在。
</logic:messagesPresent>

在上面的代码中,首先创建了一个ActionMessages对象,然后向其中添加了一个ActionMessage,将其命名为message1。再把这个ActionMessages对象存入requeset对象中,命名为Globals.MESSAGE_KEY。接下来,将<messagePresent>标记的message属性设为true(即默认在request中查找key值为Globals.MESSAGE_KEY的对象),property属性的值设为message1,判断是否存在这样一个ActionMessage对象,倘若存在,则输出相应文本。运行效果如下所示:

所查找的ActionMessage存在。

 

Empty标记

Empty标记共有两个:

  • <logic:empty>:判断所指定的字符串是否为空。
  • <logic:notEmpty>:判断所指定的字符串是否不为空。

这两个标记的使用比较简单,以下是代码示例:

<%
    pageContext.setAttribute("test1","");
%>
<logic:empty name="test1">
test1变量为空!
</logic:empty>

上面的代码首先向pageContext对象中存入一个空字符串对象,命名为test1。然后使用<logic:empty>标记判断它是否为空。以下是实际运行效果:

test1变量为空!

 

转发与重定向

转发标记

<logic:forward>标记用于进行全局转发,使用到该标记的页面一般不再编写其它内容,因为随着转发,页面将跳转。原页面中的内容也就无意义了。<logic:forward>标记和struts-config.xml文件中的<global-forward>内的子项相对应,以下是示例代码。

<logic:forwardname="index"/>

当页面中包含有上面这样一句代码时,若用户请求该页面,则会自动跳转到主页。因此,用户在浏览器内看到的会是index.jsp。

重定向标记

<logic:redirect>标记用于进行重定向请求。在JavaWeb的基本常识中用户应能首先了解过转发和重定向的区别,在此就不再赘述。因此,该标记与<logic:forward>在效果上基本一样,但它有另外几个属性分别是:

href属性:将页面重定向到href指定的完整外部链接。

forward属性:该属性与struts-config.xml中的<global-forward>内的子项相对应。即将页面重定向到forward所指定的资源。

page属性:该属性指定一个本应用内的一个网页,标记将页面重定向到这个新的网页。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值