Class BindStatus
java.lang.Object
org.springframework.web.reactive.result.view.BindStatus
Simple adapter to expose the bind status of a field or object.
Set as a variable by FreeMarker macros and other tag libraries.
Obviously, object status representations (i.e. errors at the object level rather than the field level) do not have an expression and a value but only error codes and messages. For simplicity's sake and to be able to use the same tags and macros, the same status class is used for both scenarios.
- Since:
- 5.0
- Author:
- Rossen Stoyanchev, Juergen Hoeller
- See Also:
-
Constructor Summary
ConstructorDescriptionBindStatus
(RequestContext requestContext, String path, boolean htmlEscape) Create a new BindStatus instance, representing a field or object status. -
Method Summary
Modifier and TypeMethodDescriptionfindEditor
(Class<?> valueClass) Find a PropertyEditor for the given value class, associated with the property that this bound status is currently bound to.Return the actual value of the field, i.e.Return a suitable display value for the field, i.e.Return the PropertyEditor for the property that this bind status is currently bound to.Return the first error codes for the field or object, if any.String[]
Return the error codes for the field or object, if any.Return the first error message for the field or object, if any.String[]
Return the resolved error messages for the field or object, if any.getErrorMessagesAsString
(String delimiter) Return an error message string, concatenating all messages separated by the given delimiter.Return the Errors instance (typically a BindingResult) that this bind status is currently associated with.Return a bind expression that can be used in HTML forms as input name for the respective field, ornull
if not field-specific.getPath()
Return the bean and property path for which values and errors will be resolved (e.g.getValue()
Return the current value of the field, i.e.Class<?>
Get the 'Class
' type of the field.boolean
isError()
Return if this status represents a field or object error.toString()
-
Constructor Details
-
BindStatus
public BindStatus(RequestContext requestContext, String path, boolean htmlEscape) throws IllegalStateException Create a new BindStatus instance, representing a field or object status.- Parameters:
requestContext
- the current RequestContextpath
- the bean and property path for which values and errors will be resolved (e.g. "customer.address.street")htmlEscape
- whether to HTML-escape error messages and string values- Throws:
IllegalStateException
- if no corresponding Errors object found
-
-
Method Details
-
getPath
Return the bean and property path for which values and errors will be resolved (e.g. "customer.address.street"). -
getExpression
Return a bind expression that can be used in HTML forms as input name for the respective field, ornull
if not field-specific.Returns a bind path appropriate for resubmission, e.g. "address.street". Note that the complete bind path as required by the bind tag is "customer.address.street", if bound to a "customer" bean.
-
getValue
Return the current value of the field, i.e. either the property value or a rejected update, ornull
if not field-specific.This value will be an HTML-escaped String if the original value already was a String.
-
getValueType
Get the 'Class
' type of the field. Favor this instead of 'getValue().getClass()
' since 'getValue()
' may return 'null
'. -
getActualValue
Return the actual value of the field, i.e. the raw property value, ornull
if not available. -
getDisplayValue
Return a suitable display value for the field, i.e. the stringified value if not null, and an empty string in case of a null value.This value will be an HTML-escaped String if the original value was non-null: the
toString
result of the original value will get HTML-escaped. -
isError
public boolean isError()Return if this status represents a field or object error. -
getErrorCodes
Return the error codes for the field or object, if any. Returns an empty array instead of null if none. -
getErrorCode
Return the first error codes for the field or object, if any. -
getErrorMessages
Return the resolved error messages for the field or object, if any. Returns an empty array instead of null if none. -
getErrorMessage
Return the first error message for the field or object, if any. -
getErrorMessagesAsString
Return an error message string, concatenating all messages separated by the given delimiter.- Parameters:
delimiter
- separator string, e.g. ", " or "
"- Returns:
- the error message string
-
getErrors
Return the Errors instance (typically a BindingResult) that this bind status is currently associated with.- Returns:
- the current Errors instance, or
null
if none - See Also:
-
getEditor
Return the PropertyEditor for the property that this bind status is currently bound to.- Returns:
- the current PropertyEditor, or
null
if none
-
findEditor
Find a PropertyEditor for the given value class, associated with the property that this bound status is currently bound to.- Parameters:
valueClass
- the value class that an editor is needed for- Returns:
- the associated PropertyEditor, or
null
if none
-
toString
-