freemarker 模板中直接使用 `isxxx()` 方法名会导致“期望 boolea

在 FreeMarker 中对布尔值做条件判断时,常见误区是将 Java Bean 的 getter 方法名(如 isOtherInsurance())直接当作属性使用:
<#if documentData.isOtherInsurance>
FreeMarker 默认遵循 JavaBeans 规范:若类中定义了形如 public boolean isOtherInsurance() 的方法,它会自动将其映射为名为 otherInsurance 的属性(即去掉 is 前缀,首字母小写)。因此,推荐写法是直接访问属性名:
<#if documentData.otherInsurance>✔ Да
<#else>✘ Нет
#if>
✅ 这样 FreeMarker 会自动调用 isOtherInsurance() 并取其返回的 boolean 值,语义清晰且符合模板最佳实践。
⚠️ 若因历史原因无法修改 Java 类(例如方法声明为 public Boolean isOtherInsurance() — 返回 Boolean 而非原始 boolean),或该方法未遵循标准命名(如误写为 getIsOtherInsurance()),则需显式调用方法并加括号,强制执行:
<#if documentData.isOtherInsurance()>✔ Да
<#else>✘ Нет
#if>
注意:() 不可省略,否则 documentData.isOtherInsurance 仍表示方法引用(SimpleMethodModel),而非执行结果。
? 补充建议:
总之,核心原则是:FreeMarker 条件表达式中必须出现一个明确的 boolean 值,而非方法、null 或其他类型。通过规范 Java Bean 命名或显式方法调用,即可彻底规避此类类型错误。