Привязка данных не происходит, когда связанные данные редактируются / обновляются в UI5 - PullRequest
0 голосов
/ 07 марта 2019

У меня есть страница мастер-детали, на которой есть кнопка клонирования.При нажатии на кнопку клонирования данные первого элемента списка помещаются в модель (detailModel - которая объявлена ​​в component.js), и открывается новый экран.Данные этого элемента списка привязаны к некоторым полям ввода.Когда любое из этого поля ввода обновляется / стирается, а затем пользователь переходит обратно, не сохраняя его, и снова появляется на этой странице, это обновленное / стертое поле остается пустым.Я хочу, чтобы эти данные поступали в ту область, которая приходила раньше, но она становится пустой.Данные в моей модели тоже не меняются.Ниже приведен код:

Component.js:

this.detailModel = new sap.ui.model.json.JSONModel();
        this.detailModel.setDefaultBindingMode(sap.ui.model.BindingMode.OneWay);
            sap.ui.getCore().setModel(this.detailModel, "detailModel");

Controller.js:

        /*eslint-disable no-console, no-alert */
    sap.ui.define([
        "sap/ui/core/mvc/Controller",
        "sap/ui/model/json/JSONModel",
        "hmel/TravelandGuestHouse/controller/formatter",
        "sap/m/MessageToast",
        "sap/m/MessageBox",
        "sap/m/Button",
        "sap/m/Dialog",
        "sap/m/Text",
        'sap/m/Label',
        'sap/m/TextArea'
    ], function (Controller, JSONModel, formatter, MessageToast, MessageBox, Button, Dialog, Text, Label, TextArea) {
        "use strict";
        return Controller.extend("hmel.TravelandGuestHouse.controller.CloneTravelRequest", {

            onInit: function () {
                this.router = sap.ui.core.UIComponent.getRouterFor(this);
                //for cloning request
                this.detailModel = sap.ui.getCore().getModel("detailModel");
                this.getView().setModel(this.detailModel, "detailModel");
                //for sending data to guest house screen
                this.getView().byId("date").setDateValue(new Date());
                this.router.attachRoutePatternMatched(this._handleRouteMatched, this);
            },

            _handleRouteMatched: function (evt) {
                if (evt.getParameter("name") !== "CloneTravelRequest") {
                    return;
                }

                this.getView().invalidate();

                    var that = this;

                //fetching Train Names
                $.ajax({
                    url: "/Non_sap_create_requests/odata/TravelPrpTrainDetails",
                    method: "GET",
                    dataType: "json",
                    success: function (data) {
                        that.getView().getModel("Model").setProperty("/TravelPrpTrainDetails", data.value);
                        var tempModel = that.getView().getModel("detailModel");
                        var train = tempModel.getData().TrainName;
                        var trainKey = formatter.pickTrainKeyFromModel(data.value, train);
                        that.getView().byId("trainName").setSelectedKey(trainKey);
                        that.setLocations();
                        var nameofPass = tempModel.getData().NameOfPsngr;
                        if (nameofPass === "" || nameofPass === null) {
                            that.getView().byId("nameOfP").setValue(tempModel.getData().Requestee);
                        }
                    },
                    error: function (err) {
                        console.log(err.message);

                    }
                });

                var fdate = new Date();
                this.getView().byId("date").setDateValue(new Date());
                this.getView().byId("date").setMinDate(fdate);
            }



        });
    });

1 Ответ

0 голосов
/ 09 марта 2019

Если вы можете изменить на oDataModel , вы можете использовать метод resetChanges.

Если вы не можете, вам придется сделать это немного больше вручную.Как только появятся новые окна, сохраните данные, которые пользователь изменит, и если он отменит их, восстановите сохраненные данные в jsonDataModel.

...