java.lang.Object
org.apache.wicket.model.ChainingModel<T>
org.apache.wicket.model.AbstractPropertyModel<T>
org.apache.wicket.model.PropertyModel<T>
- Type Parameters:
T
- The Model object type
- All Implemented Interfaces:
Serializable
,IDetachable
,IModel<T>
,IObjectClassAwareModel<T>
,IPropertyReflectionAwareModel<T>
,IClusterable
A PropertyModel is used to dynamically access a model using a "property expression". See
PropertyResolver
javadoc for allowed property expressions.
For example, take the following bean:
public class Person { private String name; public String getName() { return name; } public void setName(String name) { this.name = name; } }We could construct a label that dynamically fetches the name property of the given person object like this:
Person person = getSomePerson(); ... add(new Label("myLabel", new PropertyModel(person, "name"));Where 'myLabel' is the name of the component, and 'name' is the property expression to get the name property.
In the same fashion, we can create form components that work dynamically on the given model object. For instance, we could create a text field that updates the name property of a person like this:
add(new TextField("myTextField", new PropertyModel(person, "name"));
Note that the property resolver by default provides access to private members and methods. If guaranteeing encapsulation of the target objects is a big concern, you should consider using an alternative implementation.
- Author:
- Chris Turner, Eelco Hillenius, Jonathan Locke
- See Also:
-
Constructor Summary
ConstructorDescriptionPropertyModel
(Object modelObject, String expression) Construct with a wrapped (IModel) or unwrapped (non-IModel) object and a property expression that works on the given model. -
Method Summary
Modifier and TypeMethodDescriptionstatic <Z> PropertyModel<Z>
Type-infering factory methodprotected String
toString()
Methods inherited from class org.apache.wicket.model.AbstractPropertyModel
getObject, getObjectClass, getPropertyExpression, getPropertyField, getPropertyGetter, getPropertySetter, setObject
Methods inherited from class org.apache.wicket.model.ChainingModel
detach, getChainedModel, getInnermostModelOrObject, getTarget, setTarget
-
Constructor Details
-
PropertyModel
Construct with a wrapped (IModel) or unwrapped (non-IModel) object and a property expression that works on the given model.- Parameters:
modelObject
- The model object, which may or may not implement IModelexpression
- Property expression for property access
-
-
Method Details
-
toString
- Overrides:
toString
in classChainingModel<T>
-
propertyExpression
- Specified by:
propertyExpression
in classAbstractPropertyModel<T>
- Returns:
- The property expression for the component
-
of
Type-infering factory method- Type Parameters:
Z
- the of the resolved object from the property- Parameters:
parent
- object that contains the propertyproperty
- property path- Returns:
PropertyModel
instance
-