@Target(value={PARAMETER,METHOD}) @Retention(value=RUNTIME) @Documented public @interface ModelAttribute
@RequestMapping
 methods.
 Can be used to expose command objects to a web view, using
 specific attribute names, through annotating corresponding
 parameters of an @RequestMapping method.
 
Can also be used to expose reference data to a web view
 through annotating accessor methods in a controller class with
 @RequestMapping methods. Such accessor
 methods are allowed to have any arguments that
 @RequestMapping methods support, returning
 the model attribute value to expose.
 
Note however that reference data and all other model content is
 not available to web views when request processing results in an
 Exception since the exception could be raised at any time
 making the content of the model unreliable. For this reason
 @ExceptionHandler methods do not provide
 access to a Model argument.
| Modifier and Type | Optional Element and Description | 
|---|---|
| boolean | bindingAllows declaring data binding disabled directly on an  @ModelAttributemethod parameter or on the attribute returned from an@ModelAttributemethod, both of which would prevent data binding for that attribute. | 
| String | nameThe name of the model attribute to bind to. | 
| String | valueAlias for  name(). | 
@AliasFor(value="value") public abstract String name
The default model attribute name is inferred from the declared attribute type (i.e. the method parameter type or method return type), based on the non-qualified class name: e.g. "orderAddress" for class "mypackage.OrderAddress", or "orderAddressList" for "List<mypackage.OrderAddress>".
public abstract boolean binding
@ModelAttribute
 method parameter or on the attribute returned from an @ModelAttribute
 method, both of which would prevent data binding for that attribute.
 By default this is set to true in which case data binding applies.
 Set this to false to disable data binding.