SAP UI5 - Pengikatan data
Di SAP UI5, data binding conceptdigunakan untuk memperbarui data secara otomatis dengan mengikat data dengan kontrol yang menyimpan data aplikasi. Dengan data binding, Anda dapat mengikat kontrol sederhana seperti kolom teks, tombol sederhana ke data aplikasi, dan data diperbarui secara otomatis saat ada nilai baru.
Menggunakan data binding dua arah, data aplikasi diperbarui saat nilai kontrol terikat berubah. Nilainya dapat diubah melalui berbagai metode, seperti input pengguna, dll.
Di SAP UI5, model data yang berbeda dapat digunakan untuk pengikatan data. Model data ini mendukung berbagai fitur -
Model JSON
Model JSON digunakan untuk mengikat objek JavaScript ke kontrol. Model data ini adalah model sisi klien dan disarankan untuk kumpulan data kecil. Itu tidak menyediakan mekanisme apa pun untuk paging atau pemuatan di sisi server.
Fitur utama meliputi -
- Model JSON untuk data binding mendukung data dalam format notasi JavaScript.
- Ini mendukung pengikatan data dua arah.
Creating a model instance −
Var oModel = new sap.ui.model.json.JSONModel(dataUrlorData);
Model XML
Model XML data binding memungkinkan Anda mengikat kontrol ke data XML. Ini digunakan untuk objek sisi klien dan untuk kumpulan data kecil. Itu tidak menyediakan mekanisme apa pun untuk paging atau pemuatan sisi server.
Fitur utama meliputi -
- Model XML data binding mendukung data XML.
- Ini juga mendukung pengikatan data dua arah.
Creating a model instance −
Var oModel = new sap.ui.model.xml.XMLModel(dataUrlorData);
Model OData
Model OData adalah model sisi server, sehingga seluruh data tersedia di sisi server. Sisi klien hanya dapat melihat baris dan bidang dan Anda tidak dapat menggunakan pengurutan dan pemfilteran di sisi klien. Ada kebutuhan untuk mengirim permintaan ini ke server untuk menyelesaikan tugas-tugas ini.
Pengikatan data dalam model OData adalah salah satu cara, tetapi Anda dapat mengaktifkan pengikatan dua arah menggunakan dukungan tulis eksperimental.
Fitur utama meliputi -
- Model pengikatan data OData mendukung data yang sesuai dengan Odata.
- Model data ini memungkinkan Anda membuat permintaan OData dan menangani respons.
- Ini mendukung pengikatan dua arah eksperimental.
Creating a model instance −
Var oModel = new sap.ui.model.odata.ODataModel (dataUrl [,useJSON, user, pass]);
Menetapkan Model
Anda dapat menggunakan metode setModel untuk menetapkan model ke kontrol atau inti tertentu.
Sap.ui.getcore().setModel(oModel);
Untuk mengikat model untuk dilihat -
Var myView = sap.ui.view({type:sap.ui.core.mvc.ViewType.JS, viewname:”view name”});
myView.setModel(oModel);
Untuk mengikat model ke kontrol -
Var oTable = sap.ui.getCore().byId(“table”);
oTable.setModel(oModel);
Anda dapat mengikat properti kontrol ke properti model. Anda dapat mengikat properti model ke kontrol menggunakan metode bindproperty -
oControl.bindProperty(“controlProperty”, “modelProperty”);
or by using below methodvar
oControl = new sap.ui.commons.TextView({
controlProperty: “{modelProperty}”
});
Pengikatan Agregasi
Anda dapat menggunakan pengikatan agregasi untuk mengikat kumpulan nilai seperti mengikat beberapa baris ke tabel. Untuk menggunakan agregasi, Anda harus menggunakan kontrol yang berfungsi sebagai templat.
Anda dapat menentukan pengikatan agregasi menggunakan metode bindAgregation.
oComboBox.bindaggregation( “items”, “/modelaggregation”, oItemTemplate);