当我试图基于脚本数据源生成BIRT报告时,我面临着这个错误:
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 (数据资源类):
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;
}
}实体类:
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;
}
}报告模式:
<?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>发布于 2018-05-24 12:28:12
您正在尝试在不同的方法作用域中使用相同的变量。您有在fetch、open和close阶段定义的方法。这三个人都在使用一个名为count的变量。该变量的可见性固定在特定的阶段。您不能从open中的fetch访问局部变量,等等。因为您正在使用fetch中的count,在没有定义它的地方,会引发错误。
例如,要实现计数器,您可以使用reportContext.setGlobalVariable(key, value)定义一个全局变量,如下所述:日蚀论坛。
此外,对于您的特殊情况,请记住,您不需要在BIRT中计算行数:
row.__rownum的变量,用于传递当前行索引。count语句的计算列添加到数据集中即可。干杯
发布于 2018-06-25 12:06:51
一个快速而又脏的修正是在打开var关键字时从您希望在全局范围中看到的变量中删除。目前,它们被绑定到函数的作用域-- open() --因此,对于不同的函数fetch(),它们是不可见的。下面是一个可以使用的代码片段:
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
缺乏关于这一主题的介绍性文件确实令人沮丧。
https://stackoverflow.com/questions/50152342
复制相似问题