SAP UI5 Tutorial on SAP UI5 Data binding

in sap ui5, data binding concept is used to update the data automatically by binding the data with the controls that holds the application data. using data binding, you can bind simple controls like text field, simple button to application data, and data is automatically updated when there is a new value.

using two-way data binding, application data is updated when the value of bound control changes. the value can be changed via different methods, like user input, etc.

data binding concept

in sap ui5, different data models can be used for data binding. these data models support different features −

json model

json model is used to bind javascript objects to controls. this data model is a client-side model and is suggested for small data sets. it doesn’t provide any mechanism for serverside paging or loading.

key features include −

  • json model for data binding supports data in javascript notation format.
  • it supports two-way data binding.

creating a model instance −

var omodel = new sap.ui.model.json.jsonmodel(dataurlordata);

xml model

xml model of data binding allows you to bind the controls to xml data. it is used for clientside objects and for small data sets. it doesn’t provide any mechanism for server-side paging or loading.

key features include −

  • xml model of data binding supports xml data.
  • it also supports two-way data binding.

creating a model instance −

var omodel = new sap.ui.model.xml.xmlmodel(dataurlordata);

odata model

odata model is a server-side model, so entire data is available at the server side. client side can see only rows and fields and you can’t use sorting and filtering at the client side. there is a need to send this request to the server to complete these tasks.

data binding in odata model is one way but you can enable two-way binding using experimental write support.

key features include −

  • odata model of data binding supports odata compliant data.
  • this data model allows you to create odata requests and handle responses.
  • it supports experimental two-way binding.

creating a model instance −

var omodel = new sap.ui.model.odata.odatamodel (dataurl [,usejson, user, pass]);

assigning the model

you can use the setmodel method to assign the model to specific controls or core.

sap.ui.getcore().setmodel(omodel);

to bind a model to view −

var myview = sap.ui.view({type:sap.ui.core.mvc.viewtype.js, viewname:”view name”});
myview.setmodel(omodel);

to bind a model to a control −

var otable = sap.ui.getcore().byid(“table”);
otable.setmodel(omodel);

you can bind the properties of a control to model properties. you can bind the properties of a model to a control using bindproperty method −

ocontrol.bindproperty(“controlproperty”, “modelproperty”);
or by using below methodvar
ocontrol = new sap.ui.commons.textview({
   controlproperty: “{modelproperty}”
});

aggregation binding

you can use aggregation binding to bind a collection of values like binding multiple rows to a table. to use aggregation, you have to use a control that acts as a template.

you can define aggregation binding using bindagregation method.

ocombobox.bindaggregation( “items”, “/modelaggregation”, oitemtemplate);