(Quick Reference)

hasErrors

Purpose

Checks whether a bean, request scope, or model reference has any errors and if it does invokes the body of the tag. Typically used in conjunction with either eachError or renderErrors

Examples

Checks whether there are any errors for any bean throughout the request scope:

<g:hasErrors>
    <g:eachError><p>${it.defaultMessage}</p></g:eachError>
</g:hasErrors>

Checks whether there are any errors for the specified bean

<g:hasErrors bean="${book}">
    <g:eachError><p>${it.defaultMessage}</p></g:eachError>
</g:hasErrors>

Checks whether there are any errors for the field "title" of the specified "book" bean:

<g:hasErrors bean="${book}" field="title">
    <div class="errors">
       <g:renderErrors bean="${book}" field="title" as="list" />
    </div>
</g:hasErrors>

As a method call in GSP only. In this case we check for a field error on a particular field and set a CSS class on the surround div thus allowing us to highlight the error with a red border for example:

<div class="prop ${hasErrors(bean:user,field:'login', 'errors')}">
    <label for="login"><input type="text" name="login" />
</div>

Checking for errors inside a nested object:

<div class="prop ${hasErrors(bean:parent, field:'child.name', 'errors')}">
    <label for="child.name"><input type="text" name="child.name" value="${fieldValue(bean:parent,field:'child.name'} />
</div>

Description

Attributes

  • bean (optional) - The bean to check for errors
  • model (optional) - The name of the model reference to check for errors
  • field (optional) - Check if a field of the bean or model reference has errors

Source