首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >BIRT脚本数据源:未定义变量

BIRT脚本数据源:未定义变量
EN

Stack Overflow用户
提问于 2018-05-03 10:07:04
回答 2查看 1.3K关注 0票数 0

当我试图基于脚本数据源生成BIRT报告时,我面临着这个错误:

代码语言:javascript
复制
Caused by: org.mozilla.javascript.EcmaError: ReferenceError: "count" n'est pas défini (/report/data-sets/script-data-set[@id="248"]/method[@name="fetch"]#1)

英文:未定义变量“计数”

我没有找到关于这个案子的足够文件。

这些是Java类和报表模型。

谢谢你的帮助。

AppDS (数据资源类):

代码语言:javascript
复制
package projds;

import java.util.ArrayList;
import java.util.List;

public class AppDS {

    public  List<Entity> getEntities() {
        List<Entity> t = new ArrayList<Entity>();
        t.add(new Entity("A1"));
        t.add(new Entity("A2"));
        t.add(new Entity("A3"));
        t.add(new Entity("A4"));
        return t;
    }

}

实体类:

代码语言:javascript
复制
package projds;

public class Entity {

    String name;

    public Entity() {
        super();
    }

    public Entity(String name) {
        super();
        this.name = name;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

}

报告模式:

代码语言:javascript
复制
<?xml version="1.0" encoding="UTF-8"?>
<report xmlns="http://www.eclipse.org/birt/2005/design" version="3.2.23" id="1">
    <property name="createdBy">Eclipse BIRT Designer Version 4.6.0.v201606072122</property>
    <property name="units">in</property>
    <property name="iconFile">/templates/first_report.gif</property>
    <property name="bidiLayoutOrientation">ltr</property>
    <property name="imageDPI">96</property>
    <data-sources>
        <script-data-source name="dsrc1" id="247"/>
    </data-sources>
    <data-sets>
        <script-data-set name="dset1" id="248">
            <list-property name="resultSetHints">
                <structure>
                    <property name="position">0</property>
                    <property name="name">colName</property>
                    <property name="dataType">string</property>
                </structure>
            </list-property>
            <list-property name="columnHints">
                <structure>
                    <property name="columnName">colName</property>
                    <text-property name="displayName">The Name</text-property>
                </structure>
            </list-property>
            <structure name="cachedMetaData">
                <list-property name="resultSet">
                    <structure>
                        <property name="position">1</property>
                        <property name="name">colName</property>
                        <property name="dataType">string</property>
                    </structure>
                </list-property>
            </structure>
            <property name="dataSource">dsrc1</property>
            <method name="open"><![CDATA[importPackage(Packages.projds);

var dummyObject = new Object();



var gsh = new AppDS();

var data = gsh.getEntities();

var count = 0;]]></method>
            <method name="fetch"><![CDATA[if(count < data.size()) {
       row["colName"] = data.get(count).getName();
       count++;
       return true;
}

return false;]]></method>
            <method name="close"><![CDATA[dummyObject = null;

gsh = null;

data = null;

var count = 0;]]></method>
        </script-data-set>
    </data-sets>
    <styles>
        <style name="report" id="110">
            <property name="fontFamily">sans-serif</property>
            <property name="fontSize">10pt</property>
        </style>
    </styles>
    <page-setup>
        <simple-master-page name="Simple MasterPage" id="2">
            <page-footer>
                <text id="3">
                    <property name="contentType">html</property>
                    <text-property name="content"><![CDATA[<value-of>new Date()</value-of>]]></text-property>
                </text>
            </page-footer>
        </simple-master-page>
    </page-setup>
    <body>
        <label id="245">
            <property name="fontFamily">sans-serif</property>
            <property name="fontSize">x-large</property>
            <property name="fontWeight">bold</property>
            <property name="textAlign">center</property>
            <text-property name="text">Customer Listing</text-property>
        </label>
        <table id="325">
            <property name="dataSet">dset1</property>
            <list-property name="boundDataColumns">
                <structure>
                    <property name="name">colName</property>
                    <text-property name="displayName">The Name</text-property>
                    <expression name="expression" type="javascript">dataSetRow["colName"]</expression>
                    <property name="dataType">string</property>
                </structure>
            </list-property>
            <column id="334"/>
            <header>
                <row id="326">
                    <cell id="327">
                        <label id="328">
                            <text-property name="text">The Name</text-property>
                        </label>
                    </cell>
                </row>
            </header>
            <detail>
                <row id="329">
                    <cell id="330">
                        <data id="331">
                            <property name="resultSetColumn">colName</property>
                        </data>
                    </cell>
                </row>
            </detail>
            <footer>
                <row id="332">
                    <cell id="333"/>
                </row>
            </footer>
        </table>
    </body>
    <property name="pageVariables">
        <variable-element name="data">
            <property name="type">report</property>
        </variable-element>
    </property>
</report>
EN

回答 2

Stack Overflow用户

发布于 2018-05-24 12:28:12

您正在尝试在不同的方法作用域中使用相同的变量。您有在fetchopenclose阶段定义的方法。这三个人都在使用一个名为count的变量。该变量的可见性固定在特定的阶段。您不能open中的fetch访问局部变量,等等。因为您正在使用fetch中的count,在没有定义它的地方,会引发错误。

例如,要实现计数器,您可以使用reportContext.setGlobalVariable(key, value)定义一个全局变量,如下所述:日蚀论坛

此外,对于您的特殊情况,请记住,您不需要在BIRT中计算行数:

  1. 每个列绑定上都有一个名为row.__rownum的变量,用于传递当前行索引。
  2. 如果只需要行或条目的总数,只需将带有count语句的计算列添加到数据集中即可。

干杯

票数 0
EN

Stack Overflow用户

发布于 2018-06-25 12:06:51

一个快速而又脏的修正是在打开var关键字时从您希望在全局范围中看到的变量中删除。目前,它们被绑定到函数的作用域-- open() --因此,对于不同的函数fetch(),它们是不可见的。下面是一个可以使用的代码片段:

代码语言:javascript
复制
function open(){
  test = '42'
}

function fetch(){
  console.log(test)
}
open()
fetch()

在JSBin上看

如前所述,这是一个肮脏的解决办法。

您可以在不使用var关键字的情况下声明变量并为其赋值。这被称为隐式声明,不建议这样做。隐式声明给出了变量的全局范围。但是,当在过程级别声明变量时,通常不希望它具有全局范围。为了避免赋予变量全局范围,必须在变量声明中使用var关键字。

来源:https://learn.microsoft.com/en-us/scripting/javascript/reference/var-statement-javascript

缺乏关于这一主题的介绍性文件确实令人沮丧。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50152342

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档