繁体   English   中英

在JasperReports中进行比较

[英]doing comparison if else in JasperReports

我想做一个比较,如:

if <field> == 0 then "-"

有人可以告诉我使用JasperReports的语法吗?

iReport(JasperReports)使用三元运算符 例如,请考虑以下逻辑:

IF boolean condition THEN
  execute true code
ELSE
  execute false code
END IF

使用三元运算符,这变为:

boolean condition ? execute true code : execute false code

使用具有以下表达式的变量时:

$F{column_value}.intValue() == 42 ? "Life, Universe, Everything" : "Naught"

然后,当且仅当$F{column_value}的整数值等于42时,变量的值将为“Life,Universe,Everything”。

当你必须有嵌套条件时,事情变得有点迟钝。 对于这些,将嵌套条件放在括号中并放在单独的行中:

condition1 ?
  (condition2 ? true_code2 : false_code2) :
  false_code1

所以当你需要做很多事情的时候:

condition1 ?
  (condition2 ?
    (condition3 ? true_code3 : false_code3) :
    false_code2) :
  (condition4 ? true_code4 : false_code4)

ireport中表达式的示例:

(
    $F{foo} == 0 ?
    "Planned" :
    $F{foo} == 1 ?
    "Reserved" :
    $F{foo} == 2 ?
    "Canceled" :
    $F{foo} == 3 ?
    "Absent" :
    $F{foo} == 4 ?
    "Complete" :
    "Unknown"
)

使用if-else条件:

  1. 如果客户名为空,则写' - '(缺席),否则写客户名称。

小心你的现场数据类型!

<textFieldExpression class="java.lang.String">
  <![CDATA[
    $F{CustomerName} == null ? '-' : $F{CustomerName}
  ]]>
</textFieldExpression>

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM