如果datasource中的值为空,请删除文本字段?

时间:2011-09-23 04:06:56

标签: javascript jasper-reports

如果我在iReports设计器中创建Jasper报告模板文件,是否可以防止在其数据源中的字段为空时显示静态文本字段?

我知道我可以使用一定数量的JavaScript来处理报表中的数据。如果字段值为NULL或为空,是否可能隐藏元素?

1 个答案:

答案 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>