zoukankan      html  css  js  c++  java
  • Struts2中的ognl标签

    Struts2中的ognl标签介绍(property标签、iterator标签、if/elseif/else标签、url标签、radio单选框、select下拉选择框)

    1、property标签
    用于输出指定值:

    <s:set name="name" value="'kk'" />
    
    <s:property value="#name"/>

    default:可选属性,如果需要输出的属性值为null,则显示该属性指定的值

    escape:可选属性,指定是否格式化HTML代码。

    value:可选属性,指定需要输出的属性值,如果没有指定该属性,则默认输出ValueStack栈顶的值。

    id:可选属性,指定该元素的标识

    2、iterator标签

    iterator标签用于对集合进行迭代,这里的集合包含List、Set和数组。

    <s:set name="list" value="{'zhangming','xiaoi','liming'}" />
    
    <s:iterator value="#list" status="st">
    
    <font color=<s:if test="#st.odd">red</s:if><s:else>blue</s:else>>
    
    <s:property /></font><br>
    
    </s:iterator> 

    value:可选属性,指定被迭代的集合,如果没有设置该属性,则使用ValueStack栈顶的集合。

    id:可选属性,指定集合里元素的id。

    status:可选属性,该属性指定迭代时的IteratorStatus实例。该实例包含如下几个方法:

    int getCount(),返回当前迭代了几个元素。

    int getIndex(),返回当前迭代元素的索引。

    boolean isEven(),返回当前被迭代元素的索引是否是偶数

    boolean isOdd(),返回当前被迭代元素的索引是否是奇数

    boolean isFirst(),返回当前被迭代元素是否是第一个元素。

    boolean isLast(),返回当前被迭代元素是否是最后一个元素。

    3、if/elseif/else标签

    <s:set name="age" value="21" />
    
    <s:if test="#age==23">
    
    23
    
    </s:if>
    
    <s:elseif test="#age==21">
    
    21
    
    </s:elseif>
    
    <s:else>
    
    都不等
    
    </s:else> 

    4、url标签

    <s:url action="helloworld_add" namespace="/test"><s:param name="personid" value="23"/></s:url>

    生成类似如下路径:

    /struts/test/helloworld_add.action?personid=23

    红色部分为内容路径。

    当标签的属性值作为字符串类型处理时, “%”符号的用途是计算OGNL表达式的值。

    <s:set name="myurl" value="'http://www.foshanshop.net'"/>
    
       <s:url value="#myurl" /><br>
    
       <s:url value="%{#myurl}" />

    输出结果:

    #myurl

    http://www.foshanshop.net

    5、表单标签_checkboxlist复选框

    如果集合为list

    <s:checkboxlist name="list" list="{'Java','.Net','RoR','PHP'}" value="{'Java','.Net'}"/>

    生成如下html代码:

    <input type="checkbox" name="list" value="Java" checked="checked"/><label>Java</label>
    
    <input type="checkbox" name="list" value=".Net" checked="checked"/><label>.Net</label>
    
    <input type="checkbox" name="list" value="RoR"/><label>RoR</label>
    
    <input type="checkbox" name="list" value="PHP"/><label>PHP</label>
    
    如果集合为MAP
    
    <s:checkboxlist name="map" list="#{1:'瑜珈用品',2:'户外用品',3:'球类',4:'自行车'}" listKey="key" listValue="value" value="{1,2,3}"/>
    
    生成如下html代码:
    
    <input type="checkbox" name="map" value="1" checked="checked"/><label>瑜珈用品</label>
    
    <input type="checkbox" name="map" value="2" checked="checked"/><label>户外用品</label>
    
    <input type="checkbox" name="map" value="3" checked="checked"/><label>球类</label>
    
    <input type="checkbox" name="map" value="4"/><label>自行车</label>

    如果集合里存放的是javabean

     <%
    
      Person person1 = new Person(1,"第一个");
    
      Person person2 = new Person(2,"第二个");
    
      List<Person> list = new ArrayList<Person>();
    
      list.add(person1);
    
      list.add(person2);
    
      request.setAttribute("persons",list);
    
      %>
    
    <s:checkboxlist name="beans" list="#request.persons" listKey="personid" listValue="name"/>

    Personid和name为Person的属性

    生成如下html代码:

    <input type="checkbox" name=“beans" value="1"/><label>第一个</label>
    
    <input type="checkbox" name=“beans" value="2"/><label>第二个</label>

    6、表单标签_radio单选框

    该标签的使用和checkboxlist复选框相同。

    如果集合里存放的是javabean(personid和name为Person的属性)

    < s:radio name="beans" list="#request.persons" listKey="personid" listValue="name"/>

    生成如下html代码:

    <input type="radio" name="beans" id="beans1" value="1"/><label>第一个</label>
    
    <input type="radio" name="beans" id="beans2" value="2"/><label>第二个</label>

    如果集合为MAP

    <s:radio name="map" list="#{1:'瑜珈用品',2:'户外用品',3:'球类',4:'自行车'}" listKey="key" listValue="value“ value="1"/>

    生成如下html代码:

    <input type="radio" name="map" id="map1" value="1"/><label for="map1">瑜珈用品</label>
    
    <input type="radio" name="map" id="map2" value="2"/><label for="map2">户外用品</label>
    
    <input type="radio" name="map" id="map3" value="3"/><label for="map3">球类</label>
    
    <input type="radio" name="map" id="map4" value="4"/><label for="map4">自行车</label>

    如果集合为list

    <s:radio name="list" list="{'Java','.Net'}" value="'Java'"/>

    生成如下html代码:

    <input type="radio" name="list" checked="checked" value="Java"/><label>Java</label>
    <input type="radio" name="list" value=".Net"/><label>.Net</label>

    7、表单标签_select下拉选择框

    <s:select name="list" list="{'Java','.Net'}" value="'Java'"/>
    
    <select name="list" id="list">
    
        <option value="Java" selected="selected">Java</option>
    
        <option value=".Net">.Net</option>
    
    </select>
    
    <s:select name="beans" list="#request.persons" listKey="personid" listValue="name"/>
    
    <select name="beans" id="beans">
    
        <option value="1">第一个</option>
    
        <option value="2">第二个</option>
    
    </select>
    
    <s:select name="map" list="#{1:'瑜珈用品',2:'户外用品',3:'球类',4:'自行车'}" listKey="key" listValue="value" value="1"/>
    
    <select name="map" id="map">
    
        <option value="1" selected="selected">瑜珈用品</option>
    
        <option value="2">户外用品</option>
    
        <option value="3">球类</option>
    
        <option value="4">自行车</option>
    
    </select>
    
    <s:token />标签防止重复提交
    
    <s:token />标签防止重复提交,用法如下:

    第一步:在表单中加入

    <s:form action="helloworld_other" method="post" namespace="/test">
    
    
      <s:textfield name="person.name"/><s:token/><s:submit/>
    
      </s:form>

    第二步:

    <action name="helloworld_*" class="cn.csdn.action.HelloWorldAction" method="{1}">
    
           <interceptor-ref name="defaultStack" />
    
            <interceptor-ref name="token" />
    
            <result name="invalid.token">/WEB-INF/page/message.jsp</result>  
    
            <result>/WEB-INF/page/result.jsp</result>
    
    </action>

    以上配置加入了“token”拦截器和“invalid.token”结果,因为“token”拦截器在会话的token与请求的:

    严重: ParametersInterceptor - [setParameters]: Unexpected Extoken不一致时,将会直接返回“invalid.token”结果。

    在debug状态,控制台出现下面信息,是因为Action中并没有struts.token和struts.token.name属性,我们不用关心这个错误ception caught setting ‘struts.token’ on ‘class xxx: Error setting expression ‘struts.token’ with value ‘[Ljava.lang.String;@39f16f’

    严重: ParametersInterceptor - [setParameters]: Unexpected Exception caught setting ‘struts.token.name’

    8、s:set标签的用法

     set标签 用于将某个值放入指定范围内。例如application、session范围等。
    
    当某个值所在的对象图深度非常深时,例如如下:person.worker.wife.parent.age,每次访问该值不仅性能地下,而可读性也很差。解决这个问题,可以将改该值设置成一个新值,并放入特定范围内。
    
    set标签属性:
    
        name: 必填,重新生成的新变量的名字
        scope: 可选,指定新变量被放置的范围,该属性可以接受application、session、request、page或action 5个值。如果没有指定,默认是放置在Stack Context中。
        value: 可选,指定将赋给变量的值。如果没指定,则将ValueStack栈顶的值赋给新变量。
        var: 可选,指定该元素的引用ID,如果指定了将会将该值放在ValueStack中!
    
    set标签用于生成一个新变量,并把该变量放置到指定的范围内,这样就允许直接使用JSP表达式语言来访问这些变量,也可以通过struts2标签来访问!
    
    eg:
    
    <!--使用param标签为JavaBean实例传入参数-->
    
    <s:bean name="lee.Person" id="p">
    
        <s:param name="name" value="'yeeku'"/>
    
        <s:param name="age" value="29"/>
    
    </s:bean>
    
    将Stack Context中的p值放入默认范围内。<br>
    
    <s:set value="#p" name="xxx"/>
    
    <s:property value="#xxx.name"/> <br>
    
    将Stack Context中的p值放入application范围内<br>
    
    <s:set value="#p" name="xxx" scope="application"/>
    
    <s:property value="#attr.xxx.name"/> <br>
    
    将Stack Context中的p值放入session范围内<br>
    
    <s:set value="#p" name="xxx" scope="session"/>
    
    <!--使用JSP2.0表达式语言直接访问session中的属性-->
    
    ${sessionScope.xxx.name}<br>
    
    
    取出集合中的值赋给<set标签
    
    <s:iterator id="dmsDocumentinfo" value="#request.dmsDocumentinfos">
    
                  //从集合中取值赋给set声明的变量
    
        <s:set name="str" value="#dmsDocumentinfo.documentDesc"></s:set>
    
    
        //在页面显示set标签的值
    
        <s:property value="#str" />
    
    </s:iterator>
    
  • 相关阅读:
    java中Objenesis库简单使用
    java魔法类之ReflectionFactory介绍
    求与一个数最接近的2的N次幂
    java魔法类之Unsafe介绍
    java中如何通过程序检测线程死锁
    jQuery.fullpage自定义高度(demo详解)
    angular diretive中 compile controller link的区分及编译顺序
    div水平垂直居中的几种方法(面试问题)
    angular 双ng-repeat显示隐藏
    快速应用rem
  • 原文地址:https://www.cnblogs.com/lllini/p/11955366.html
Copyright © 2011-2022 走看看