如果我在iReports设计器中创建Jasper报告模板文件,是否可以防止在其数据源中的字段为空时显示静态文本字段?
我知道我可以使用一定数量的JavaScript来处理报表中的数据。如果字段值为NULL或为空,是否可能隐藏元素?
答案 0 :(得分:7)
如果字段值为NULL或者是否可能隐藏元素 空?
是的,这是可能的。
的 1。对静态和文本字段使用“打印表达式时”属性
用于隐藏NULL或“空”字符串值的示例:
<staticText>
<reportElement x="52" y="16" width="100" height="20">
<printWhenExpression><![CDATA[$F{field1} != null && $F{field1}.trim().length()>0]]></printWhenExpression>
</reportElement>
<textElement/>
<text><![CDATA[Static text]]></text>
</staticText>
<textField>
<reportElement x="170" y="15" width="100" height="20">
<printWhenExpression><![CDATA[$F{field2} != null && $F{field2}.trim().length()>0]]></printWhenExpression>
</reportElement>
<textElement/>
<textFieldExpression><![CDATA[$F{field2}]]></textFieldExpression>
</textField>
的 2。对文本字段使用“Blank When Null”属性
隐藏带有NULL值的文本字段的示例:
<textField isBlankWhenNull="true">
<reportElement x="340" y="15" width="100" height="20"/>
<textElement/>
<textFieldExpression><![CDATA[$F{field3}]]></textFieldExpression>
</textField>
第3。对空数据源使用“无数据”区域 - 无数据返回
如果datasource为空,则可以将“No Data”波段与您需要的静态字段一起使用。要使用此频段,您必须将“无数据时”报告的属性设置为“无数据部分”。
样品:
<?xml version="1.0" encoding="UTF-8"?>
<jasperReport .. whenNoDataType="NoDataSection" ..>
...
<noData>
<band height="50">
<staticText>
<reportElement x="236" y="18" width="100" height="20"/>
<textElement/>
<text><![CDATA[No data]]></text>
</staticText>
</band>
</noData>
</jasperReport>