Is there a simple way in thymeleaf to show the content of an attribute property if the property and the attribute exist? If there's an attribute "error" with a property "summary" in my html page, I'd like to show it:
<span th:text="${error.summary}">error summary</span>
If there is no attribute "error" the following error is raised:
org.springframework.expression.spel.SpelEvaluationException: EL1007E:(pos 0): Field or property 'summary' cannot be found on null
Currently I'm using the following approach, which just seems too complicated.
<span th:if="${error != null and error.summary != null}"><span th:text="${error.summary}">error summary</span></span>
Is there a simpler way to achieve that?
Using Switch Case Statement - th:switch Attribute To achieve similar to if-else condition in Thymeleaf , we can use th:switch attribute. Thymeleaf at the first step will evaluate ${condition} expression and if the value is true it will print p tag with TRUE text.
Variable expressions are OGNL expressions –or Spring EL if you're integrating Thymeleaf with Spring. *{} is used for selection expressions. Selection expressions are just like variable expressions, except they will be executed on a previously selected object. #{} is used for message (i18n) expressions.
Another way of accessing request parameters in thymeleaf is by using #httpServletRequest utility object which gives direct access to javax. servlet. http. HttpServletRequest object.
Thymeleaf provides a special attribute th:field responsible for binding input fields with a property in the bean class. This attribute behaves differently depending on whether it is attached to. Thymeleaf supports all-new input types introduced in HTML5 such as type="color" or type="datetime" .
Sure! Since the processor associated with the th:if
attribute has a higher precedence than the one associated with the th:text
attribute, it will be evaluated first. Thus you can write:
<span th:if="${error != null && error.summary != null}" th:text="${error.summary}">Static summary</span>
You could even shorten it using:
<span th:text="${error?.summary}">Static summary</span>
But I think in this case, whether the summary exist or not, the span tag will be created, which is a bit ugly.
See more info about conditional expressions here.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With