When to Save Data from UI Components to the Data Source"

From Documentation
Line 9: Line 9:
 
* <tt>event-name</tt> represents the event name
 
* <tt>event-name</tt> represents the event name
  
Multiple definition is allowed and would be called one by one.  
+
It is allowed to have multiple definitions and they would be called one by one.  
  
In the following example, Data Binding Manager will save the attribute "<tt>value</tt>" of <tt>Textbox</tt> "<tt>firstName</tt>" into "<tt>person.firstName</tt>" when the <tt>Textbox</tt> itself fires "<tt>onChange</tt>" event.  
+
In the following example, the Data Binding Manager will save the attribute "<tt>value</tt>" of <tt>Textbox</tt> "<tt>firstName</tt>" into "<tt>person.firstName</tt>" when the <tt>Textbox</tt> itself fires "<tt>onChange</tt>" event.  
  
 
<source lang="xml" >
 
<source lang="xml" >

Revision as of 01:55, 25 July 2011


DocumentationZK Developer's ReferenceData BindingWhen to Save Data from UI Components to the Data Source
When to Save Data from UI Components to the Data Source


The Data Binding Manager is triggered by events or users' activities. Thus, you must specify events in the ZUML annotation expression with save-when tag expression to tell the Data Binding Manager when to save the attribute of the component into the data source.

<component-name attribute-name="@{bean-name.attribute-name,save-when='component-id.event-name'}"/>


  • component-id represents the ID of a UI component
  • event-name represents the event name

It is allowed to have multiple definitions and they would be called one by one.

In the following example, the Data Binding Manager will save the attribute "value" of Textbox "firstName" into "person.firstName" when the Textbox itself fires "onChange" event.

<?init class="org.zkoss.zkplus.databind.AnnotateDataBinderInit"?>

<window width="500px">
	<zscript><![CDATA[
		Person person = new Person();
		person.setFirstName("Bill");
		person.setLastName("Gates");
	]]>
	</zscript>

	<listbox>
		<listhead>
			<listheader label="First Name" width="100px"/>
			<listheader label="Last Name" width="100px"/>
			<listheader label="Full Name" width="100px"/>
		</listhead>
		<listitem>
			<listcell>
				<textbox id="firstName" value="@{person.firstName, save-when='self.onChange'}"/>
			</listcell>
			<listcell>
				<textbox id="lastName" value="@{person.lastName, save-when='self.onChange'}"/>
			</listcell>
			<listcell label="@{person.fullName}"/>
		</listitem>
	</listbox>
</window>

Version History

Last Update : 2011/07/25


Version Date Content
     



Last Update : 2011/07/25

Copyright © Potix Corporation. This article is licensed under GNU Free Documentation License.