[英]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条件:
小心你的现场数据类型!
<textFieldExpression class="java.lang.String">
<![CDATA[
$F{CustomerName} == null ? '-' : $F{CustomerName}
]]>
</textFieldExpression>
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.