English 中文(简体)
Nullable date in Freemarker
原标题:

This is a piece of my freemarker template:

${order.needByDate?if_exists?date}

I want it to work as following:

  • if needByDate is null, then write nothing
  • if it is not null, then write the date part

The above works only in second scenario. What is the correct way to achieve this?

最佳回答

There may be a smarter way of doing this but the following should do the job.

<#if order.needByDate??>${order.needByDate?date}</#if>
问题回答

This should also work

${(order.needByDate?date)!}

The parentheses are necessary

You can also add a default value such as "n/a" like this

${(order.needByDate?date)!"n/a"}

A solution that considers null and empty-string values:

For Freemarker version 2.3.23 or newer:

${aDateField?has_content?then(aDateField?datetime?string["MM/dd/yyyy hh:mm:ss"],"")}

For older versions:

<#if aDateField?has_content>
${aDateField?datetime?string["MM/dd/yyyy hh:mm:ss"]}
</#if>

You can test it at https://try.freemarker.apache.org/





相关问题
Spring Properties File

Hi have this j2ee web application developed using spring framework. I have a problem with rendering mnessages in nihongo characters from the properties file. I tried converting the file to ascii using ...

Logging a global ID in multiple components

I have a system which contains multiple applications connected together using JMS and Spring Integration. Messages get sent along a chain of applications. [App A] -> [App B] -> [App C] We set a ...

Java Library Size

If I m given two Java Libraries in Jar format, 1 having no bells and whistles, and the other having lots of them that will mostly go unused.... my question is: How will the larger, mostly unused ...

How to get the Array Class for a given Class in Java?

I have a Class variable that holds a certain type and I need to get a variable that holds the corresponding array class. The best I could come up with is this: Class arrayOfFooClass = java.lang....

SQLite , Derby vs file system

I m working on a Java desktop application that reads and writes from/to different files. I think a better solution would be to replace the file system by a SQLite database. How hard is it to migrate ...

热门标签