SAP UI5-데이터 바인딩

SAP UI5에서 data binding concept데이터를 애플리케이션 데이터를 보유하는 컨트롤과 바인딩하여 데이터를 자동으로 업데이트하는 데 사용됩니다. 데이터 바인딩을 사용하면 텍스트 필드, 간단한 버튼과 같은 간단한 컨트롤을 애플리케이션 데이터에 바인딩 할 수 있으며 새 값이 있으면 데이터가 자동으로 업데이트됩니다.

양방향 데이터 바인딩을 사용하면 바인딩 된 컨트롤의 값이 변경 될 때 응용 프로그램 데이터가 업데이트됩니다. 값은 사용자 입력 등과 같은 다양한 방법을 통해 변경할 수 있습니다.

SAP UI5에서는 데이터 바인딩에 다른 데이터 모델을 사용할 수 있습니다. 이러한 데이터 모델은 다양한 기능을 지원합니다.

JSON 모델

JSON 모델은 JavaScript 개체를 컨트롤에 바인딩하는 데 사용됩니다. 이 데이터 모델은 클라이언트 측 모델이며 소규모 데이터 세트에 권장됩니다. 서버 측 페이징 또는로드를위한 메커니즘을 제공하지 않습니다.

주요 기능은 다음과 같습니다-

  • 데이터 바인딩을위한 JSON 모델은 JavaScript 표기법 형식의 데이터를 지원합니다.
  • 양방향 데이터 바인딩을 지원합니다.

Creating a model instance −

Var oModel = new sap.ui.model.json.JSONModel(dataUrlorData);

XML 모델

데이터 바인딩의 XML 모델을 사용하면 컨트롤을 XML 데이터에 바인딩 할 수 있습니다. 클라이언트 측 개체 및 작은 데이터 세트에 사용됩니다. 서버 측 페이징 또는로드를위한 메커니즘을 제공하지 않습니다.

주요 기능은 다음과 같습니다-

  • 데이터 바인딩의 XML 모델은 XML 데이터를 지원합니다.
  • 또한 양방향 데이터 바인딩을 지원합니다.

Creating a model instance −

Var oModel = new sap.ui.model.xml.XMLModel(dataUrlorData);

OData 모델

OData 모델은 서버 측 모델이므로 전체 데이터를 서버 측에서 사용할 수 있습니다. 클라이언트 측은 행과 필드 만 볼 수 있으며 클라이언트 측에서는 정렬 및 필터링을 사용할 수 없습니다. 이러한 작업을 완료하려면이 요청을 서버로 보내야합니다.

OData 모델의 데이터 바인딩은 한 가지 방법이지만 실험적 쓰기 지원을 사용하여 양방향 바인딩을 활성화 할 수 있습니다.

주요 기능은 다음과 같습니다-

  • 데이터 바인딩의 OData 모델은 Odata 호환 데이터를 지원합니다.
  • 이 데이터 모델을 사용하면 OData 요청을 만들고 응답을 처리 할 수 ​​있습니다.
  • 실험적인 양방향 바인딩을 지원합니다.

Creating a model instance −

Var oModel = new sap.ui.model.odata.ODataModel (dataUrl [,useJSON, user, pass]);

모델 할당

setModel 메소드를 사용하여 특정 컨트롤 또는 코어에 모델을 할당 할 수 있습니다.

Sap.ui.getcore().setModel(oModel);

보기에 모델을 바인딩하려면-

Var myView = sap.ui.view({type:sap.ui.core.mvc.ViewType.JS, viewname:”view name”});
myView.setModel(oModel);

모델을 컨트롤에 바인딩하려면-

Var oTable = sap.ui.getCore().byId(“table”);
oTable.setModel(oModel);

컨트롤의 속성을 모델 속성에 바인딩 할 수 있습니다. bindproperty 메서드를 사용하여 모델의 속성을 컨트롤에 바인딩 할 수 있습니다.

oControl.bindProperty(“controlProperty”, “modelProperty”);
or by using below methodvar
oControl = new sap.ui.commons.TextView({
   controlProperty: “{modelProperty}”
});

집계 바인딩

집계 바인딩을 사용하여 여러 행을 테이블에 바인딩하는 것과 같은 값 컬렉션을 바인딩 할 수 있습니다. 집계를 사용하려면 템플릿 역할을하는 컨트롤을 사용해야합니다.

bindAgregation 메서드를 사용하여 집계 바인딩을 정의 할 수 있습니다.

oComboBox.bindaggregation( “items”, “/modelaggregation”, oItemTemplate);