我有一个用XSL编码的表,该表用于在执行时生成pdf。当用户在CountryGroup表单元格中输入数据时出现问题。如果数据中没有空格,它将打破单元格的边界,并且数据将溢出到其他单元格中,从而使文档不可读。
我正在尝试找出一种使文本自动换行的方法。请参见下面的代码段:
<fo:table-cell border="1pt solid black" display-align="after"><fo:block>Customer Seq Range</fo:block></fo:table-cell>
<fo:table-cell border="1pt solid black" display-align="after"><fo:block>Label Code</fo:block></fo:table-cell>
<fo:table-cell border="1pt solid black" display-align="after"><fo:block>Labelled Lot</fo:block></fo:table-cell>
<fo:table-cell border="1pt solid black" display-align="after"><fo:block>Country Group</fo:block></fo:table-cell> <!--NCCRC200003 Country Group -->
<fo:table-cell border="1pt solid black" display-align="after"><fo:block>Lot Expiry</fo:block></fo:table-cell>
<fo:table-cell border="1pt solid black" display-align="after"><fo:block>QTY</fo:block></fo:table-cell>
</fo:table-row>
</fo:table-header>
<fo:table-body>
<fo:table-row font-size="9pt" font-weight="normal">
<fo:table-cell border="1pt solid black" padding="3mm 0mm" display-align="center"><fo:block><xsl:value-of select="ItemNumber"/></fo:block></fo:table-cell>
<fo:table-cell border="1pt solid black" padding="3mm 0mm" display-align="center"><fo:block><xsl:value-of select="RangeStart"/>-<xsl:value-of select="RangeEnd"/></fo:block></fo:table-cell>
<fo:table-cell border="1pt solid black" padding="3mm 0mm" display-align="center"><fo:block><xsl:value-of select="CustRangeStart"/>-<xsl:value-of select="CustRangeEnd"/></fo:block></fo:table-cell>
<fo:table-cell border="1pt solid black" padding="3mm 0mm" display-align="center"><fo:block><xsl:value-of select="LabelType"/></fo:block></fo:table-cell>
<fo:table-cell border="1pt solid black" padding="3mm 0mm" display-align="center"><fo:block><xsl:value-of select="OtherLot"/></fo:block></fo:table-cell>
<fo:table-cell border="1pt solid black" padding="3mm 0mm" display-align="center"><fo:block><xsl:value-of select="CountryGroup"/></fo:block></fo:table-cell> <!--NCCRC200003 Country Group. -->
<fo:table-cell border="1pt solid black" padding="3mm 0mm" display-align="center"><fo:block><xsl:value-of select="ExpiryDate"/></fo:block></fo:table-cell>
<fo:table-cell border="1pt solid black" padding="3mm 0mm" display-align="center"><fo:block><xsl:value-of select="Quantity"/></fo:block></fo:table-cell>
</fo:table-row>
答案 0 :(得分:0)
如果您希望在文本中不存在空格的情况下将一个块包装成几行,请尝试将属性wrap-option
设置为"wrap"
。
如果我重新输入您的代码,则您具有:
<fo:table-cell border="1pt solid black" padding="3mm 0mm"
display-align="center">
<fo:block>
<xsl:value-of select="CountryGroup"/>
</fo:block>
</fo:table-cell>
我将通过以下方式更改上面的代码
<fo:table-cell border="1pt solid black" padding="3mm 0mm"
display-align="center">
<fo:block wrap-option="wrap"><!-- added wrap-option attribute here -->
<xsl:value-of select="CountryGroup"/>
</fo:block>
</fo:table-cell>
关于此的更多信息:XSL-FO fop. Long text flows into adjacent cells/block, obscuring stuff there
如果这不起作用,则可以在块中注入零宽度的空格,希望这将有助于将文本包装成几行:
<xsl:template name="string-replace-all">
<xsl:param name="text" />
<xsl:param name="replace" />
<xsl:param name="by" />
<xsl:choose>
<xsl:when test="contains($text, $replace)">
<xsl:value-of select="substring-before($text,$replace)" />
<xsl:value-of select="$by" />
<xsl:call-template name="string-replace-all">
<xsl:with-param name="text"
select="substring-after($text,$replace)" />
<xsl:with-param name="replace" select="$replace" />
<xsl:with-param name="by" select="$by" />
</xsl:call-template>
</xsl:when>
<xsl:otherwise>
<xsl:value-of select="$text" />
</xsl:otherwise>
</xsl:choose>
</xsl:template>
这是我在此处找到的代码段:XSLT 1.0: Replacing all occurences of a string in a node-set
代替
<xsl:value-of select="CountryGroup"/>
您可以尝试(根据以下建议进行编辑):
<xsl:call-template name="string-replace-all">
<xsl:with-param name="text" select="CountryGroup"/>
<xsl:with-param name="replace" select="','"/>
<xsl:with-param name="by" select="',​'"/>
</xsl:call-template>
对于零宽度空间,我使用了其Unicode ​
。如果您使用其他编码,则需要对此进行调整。