zoukankan      html  css  js  c++  java
  • struts2 s:set标签

    set标签是将某个值放到指定范围内, 比如说 student.teacher.parent.age 每次访问这个属性不仅性能低,而且代码可读性很差,为了解决这个问题,可以将这个值设置为一个新值,并且放入指定范围内

    set标签属性:

    1. name: 必填,重新生成的新变量的名字
    2. scope: 可选,指定新变量被放置的范围,该属性可以接受application、session、request、page或action 5个值。如果没有指定,默认是放置在Stack Context中。
    3. value: 可选,指定将赋给变量的值。如果没指定,则将ValueStack栈顶的值赋给新变量。
    4. 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>

    赋常量的例子:
    如果value中要赋的是常量,如果直接
    <s:set name="page2" value="listMaterialEnt"  scope="session"> </s:set>
    这样在页面中是访问不到listMaterialEnt这个字符串,怎么样才能赋这个字符串常量值呢?

    加个单引号就搞定,如下:

    <s:set name="page2" value="'listMaterialEnt'"  scope="session"> </s:set>

  • 相关阅读:
    【转】PowerDesigner数据库视图同时显示Code和Name
    [转]BT原理分析
    异常机制及throw与throws的区别(转)
    BS与CS的联系与区别。
    ASP.NET和C#的区别/
    上百例Silverlight网站及演示汇总,供友参考
    Bing Maps进阶系列九:使用MapCruncher进行地图切片并集成进Bing Maps
    【Silverlight】Bing Maps学习系列(八):使用Bing Maps Silverlight Control加载自己部署的Google Maps
    学习MAP 地图好地址
    Bing必应地图中国API
  • 原文地址:https://www.cnblogs.com/yingsong/p/4814750.html
Copyright © 2011-2022 走看看