首页 >Java >java教程 >如何在 JasperReports 的详细信息区域中显示 JavaBean 列表?

如何在 JasperReports 的详细信息区域中显示 JavaBean 列表?

Linda Hamilton
Linda Hamilton原创
2024-11-25 22:11:12166浏览

How to Display a JavaBean's List in JasperReports' Detail Band?

JavaBean包含 java.util.List:在 JasperReports 中显示

问题

A JavaBean 包含一个java.util.List。如何将此列表的数据显示在 JasperReports 文档的 Detail 区域中?

解决方案

  1. 使用 _THIS 表达式: 利用_THIS 表达式来访问 JavaBean
  2. 应用 jr:list 组件:Detail 带中合并 jr:list 组件以迭代列表的项目。

工作示例代码

// Java source to generate the report
...

// DataSource using JRBeanCollectionDataSource
private static JRDataSource getDataSource() {
    Collection<BeanWithList> coll = ...;
    return new JRBeanCollectionDataSource(coll);
}

// JavaBean
public class BeanWithList {
    private List<String> cities;
    // ...

    // Ensure a public getter for field extraction
    public List<String> getCities() {
        return this.cities;
    }
}

// jrxml file
...

// Subdataset for iterating through the list
<subDataset name="dataset1">
    <field name="city" class="java.lang.String">
        <fieldDescription><![CDATA[_THIS]]></fieldDescription>
    </field>
</subDataset>

// Detail band with jr:list component
<detail>
    ...
    <componentElement>
        <!-- jr:list component -->
        <jr:list ...>
            <datasetRun subDataset="dataset1">
                <!-- DataSource expression using JRBeanCollectionDataSource -->
                <dataSourceExpression><![CDATA[new net.sf.jasperreports.engine.data.JRBeanCollectionDataSource($F{cities})]]></dataSourceExpression>
            </datasetRun>
            <jr:listContents ...>
                <textField ...>
                    <textFieldExpression><![CDATA[$F{city}]]></textFieldExpression>
                </textField>
            </jr:listContents>
        </jr:list>
    </componentElement>
    ...
</detail>
...

结果

此配置生成一个报告,显示 详细信息 范围内的列表数据。

其他信息

  • 其他相关问题解决此问题topic:

    • “如何打印 iReport 中另一个列表中包含的字符串列表?”
    • “将基本类型对象列表作为子报表的数据源传递”

以上是如何在 JasperReports 的详细信息区域中显示 JavaBean 列表?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn