2013-04-09 43 views
1

我在使用xsl中的if/else条件时遇到了问题。在下面的代码片段中,我有一个从数据库值中获取其值的表。最初,我的代码看起来像如何使用If/Else在表格上选择默认值

<fo:table-body> 
         <xsl:for-each select="//ROWSET3_ROW"> 
          <fo:table-row> 
           <fo:table-cell xsl:use-attribute-sets="cell"> 
            <fo:block> 
             <xsl:value-of select = "MODIFICATION_NUMBER" /> 
            </fo:block> 
           </fo:table-cell> 
           <fo:table-cell xsl:use-attribute-sets="cell"> 
            <fo:block> 
             <xsl:value-of select = "STATUS_DATE" /> 
            </fo:block> 
           </fo:table-cell> 
. 
. 
.... 

凡MODIFICATION_NUMBER,STATUS_DATE,和其他属性来从XML表:

<ROWSET3> 
<ROWSET3_ROW> 
    <MODIFICATION_NUMBER>0</MODIFICATION_NUMBER> 
    <SURVEY_JOB_STATUS_ID /> 
    <STATUS_DATE>5/13/2008</STATUS_DATE> 
    <STATUS_NOTES /> 

在某些情况下,也有在数据库中,这些值空值,所以我试图把条件放在那些没有值的列上。所以,如果选择的值是NULL,那么在那里放一个随机字符,比如' - '。我的代码似乎没有工作

<fo:table-cell xsl:use-attribute-sets="cell"> 
            <fo:block> 
             <xsl:value-of select = "30" /> 
             <xsl:choose> 
              <xsl:when test = "STATUS_NOTES != ''"> 
               <xsl:value-of select = "STATUS_NOTES"/> 
              </xsl:when> 
               <xsl:otherwise> 
               <xsl:value-of select = "blank" /> 
               </xsl:otherwise> 
               </xsl:choose> 
            </fo:block> 
           </fo:table-cell> 

这是我试图做的。任何帮助将不胜感激。

+0

'值的选择=“BL ank“会插入当前模式中名为'blank'的第一个子元素的值(或者在更可能的情况下没有这个元素的情况下为空字符串)。如果你想让文字字符串“空白”而不是使用'xsl:text',或者只用'空白' – 2013-04-09 19:55:27

+0

如果OP想要使用' - ',他需要写' ' – Hanno 2013-04-09 19:58:44

回答

0
<xsl:choose> 
    <xsl:when test = "STATUS_NOTES"> 
     <xsl:value-of select = "STATUS_NOTES"/> 
    </xsl:when> 
    <xsl:otherwise> 
     <xsl:value-of select = "blank" /> 
    </xsl:otherwise> 
</xsl:choose> 

如果STATUS_NOTES是一个空元素,这将起作用。如果它也可以包含空字符串,则可以使用test="not(normalize-space(STATUS_NOTES) = '')"

0

使用

<xsl:value-of select= 
     "Concat(STATUS_NOTES, substring('blank', 6 - 5*boolean(STATUS_NOTES)))"/> 

上面一行程序使用以下事实:由定义

number(true()) = 1 

number(false()) = 0