<s:if test>的应用

分类: java   18257人阅读  评论(0)  收藏  举报
原文 :
http://blog.youkuaiyun.com/chenqqabcdchenqqabcd/article/details/6726673
字符串N一定要用“”双引号包含,从test的包含则用单引号 ‘ ’,如果相反,则不能正确判断该属性是否与该字符串相等。

正确:
<s:if test='activityBean.searchForce=="N" '>

错误:

<s:if test="activityBean.searchForce=='N' ">

因为java是强类型语言,单引号表示char类型,只能赋给一个字符给char类型,
而双引号则表示String类型

所以我的activityBean.searchForce属性是String类型,那么N必须要用双引号

/*******************************************
例如这个语句 
要判断struts堆栈里systemSettingModel.settingValue 是否等于 "A" 
写成 
<s:if test="systemSettingModel.settingValue == 'A'">...</s:if> 
是不对的。 
这样A被认为是字符,而systemSettingModel.settingValue是单字符的字符串,不匹配 


应写成 
<s:if test='systemSettingModel.settingValue == "A"'>。。。 </s:if> 
或 
<s:if test="systemSettingModel.settingValue == \"A\"">... </s:if> 

参考: 
http://struts.apache.org/2.1.8.1/docs/why-wont-the-if-tag-evaluate-a-one-char-string.html 

另外systemSettingModel.settingValue的值可以这样取得 
${systemSettingModel.settingValue} 
<s:property value="systemSettingModel.settingValue"/> 
<s:property value="#request.systemSettingModel.settingValue"/> 

#表示不在struts堆栈里,没有#表示从struts堆栈里取 


/***********************************
Struts2堆栈
struts2中的标签 
    s:a            中的href 什么时候使用“# ” 什么时候该用“%{ }”  什么时候该用“%{# }” 什么时候用“” 
    s:select      中的list 什么时候使用“# ” 什么时候该用“%{ }”  什么时候该用“%{# }” 什么时候用“” 
    s:if          中的test 什么时候使用“# ” 什么时候该用“%{ }”  什么时候该用“%{# }” 什么时候用“” 
    s:iterator    中的value什么时候使用“# ” 什么时候该用“%{ }”  什么时候该用“%{# }” 什么时候用“” 
    s:checkboxlist 中的list 什么时候使用“# ” 什么时候该用“%{ }”  什么时候该用“%{# }” 什么时候用“”



Struts2中有值堆栈和堆栈上下文的概念,你用 <s:debug />可以看出. 

S标签中用#可以取出堆栈上下文中的存放的对象. 
用%{}可以取出存在值堆栈中的Action对象,直接调用它的方法.例如你的Action如果继承了ActionSupport .那么在页面标签中,用%{getText('key')}的方式可以拿出国际化信息. %{#}, 这是JSP2.1最新规范中的语法,是Struts2为其解决兼容性问题而写成%{#}的



在域对象中使用%{#} 
比如%{#session.user.userName} 
将获得user对象的 userName属性值



%{}强调的是从你设定的root点取

%{}用于计算表达式 
      如%{10+20}结果将输出30 
      如%{"a"+"b"}结果将输出"ab" 
#通常强调从上下文取 
      如#parameters.name[0]等价于request.getParameter("name") 
      如#session.name等价于session.getAttribute("name") 
      如#request.name等价于request.getAttribute("name") 
%{#}仍然用于计算表达式,只不过操作元可以是变量 
      如先定义一个变量 
      <s:set name="age" value="%{25}"/> 
      则%{#age}将输出25,也可以省略"#",写为%{age} 
      若将age加10,可这么写: 
      %{#age+10},将输出30.不能省略"#"。也就说变量用于计算时不能省略"#" 
<!-- 表格处理(增强修正版) --> <xsl:template match="w:tbl"> <xsl:variable name="colCount" select="count(w:tblGrid/w:gridCol)"/> <fo:table table-layout="fixed" width="100%" border-collapse="collapse"> <!-- 生成精确列定义 --> <xsl:for-each select="w:tblGrid/w:gridCol"> <fo:table-column column-width="{@w:w div 20}pt"/> </xsl:for-each> <fo:table-body> <!-- 列溢出检测逻辑保持不变 --> <xsl:if test="count(w:tr[1]/w:tc) > $colCount"> <fo:table-row> <fo:table-cell number-columns-spanned="{$colCount}"> <fo:block color="red">表格列数溢出警告</fo:block> </fo:table-cell> </fo:table-row> </xsl:if> <xsl:apply-templates select="w:tr"/> </fo:table-body> </fo:table> </xsl:template> <!-- 表格行处理(优化版) --> <xsl:template match="w:tr"> <fo:table-row> <!-- 移除过滤条件,改为处理所有单元格 --> <xsl:apply-templates select="w:tc"/> </fo:table-row> </xsl:template> <!-- 单元格处理(列合并修复版) --> <xsl:template match="w:tc"> <fo:table-cell border="1pt solid black" padding="2pt" display-align="center"> <!-- 列合并关键修复 --> <xsl:variable name="totalCols" select="count(ancestor::w:tbl/w:tblGrid/w:gridCol)"/> <!-- 修正前序列数计算逻辑 --> <xsl:variable name="precedingSpanSum"> <xsl:choose> <xsl:when test="preceding-sibling::w:tc"> <!-- 计算前序单元格实际占用的总列数 --> <xsl:value-of select="sum(preceding-sibling::w:tc/w:tcPr/w:gridSpan/@w:val) + count(preceding-sibling::w:tc[not(w:tcPr/w:gridSpan)])"/> </xsl:when> <xsl:otherwise>0</xsl:otherwise> </xsl:choose> </xsl:variable> <!-- 安全列合并计算 --> <xsl:if test="w:tcPr/w:gridSpan"> <xsl:variable name="declaredSpan" select="w:tcPr/w:gridSpan/@w:val"/> <xsl:variable name="remainingCols" select="$totalCols - $precedingSpanSum"/> <xsl:attribute name="number-columns-spanned"> <xsl:choose> <!-- 当声明跨度超过剩余列数时取剩余值 --> <xsl:when test="$declaredSpan > $remainingCols"> <xsl:value-of select="$remainingCols"/> </xsl:when> <!-- 正常情况直接使用声明值 --> <xsl:otherwise> <xsl:value-of select="$declaredSpan"/> </xsl:otherwise> </xsl:choose> </xsl:attribute> </xsl:if> <!-- 行合并逻辑保持不变 --> <xsl:if test="w:tcPr/w:vMerge[@w:val='restart']"> <xsl:variable name="actualRowSpan" select="count(following-sibling::w:tr[1]/w:tc[1][w:tcPr/w:vMerge/@w:val='continue']) + 1"/> <xsl:attribute name="number-rows-spanned"> <xsl:value-of select="($actualRowSpan > 10) * 1 + ($actualRowSpan <= 10) * $actualRowSpan"/> </xsl:attribute> </xsl:if> <fo:block linefeed-treatment="ignore" white-space-collapse="true"> <xsl:apply-templates select=".//w:p"/> </fo:block> </fo:table-cell> </xsl:template>这个改完后,行格式对了,但是该合并展示的并没有合并起来,就是没有执行合并并居中的操作,应该怎么再改一下
最新发布
03-08
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值