删除一个视图并单击再次打开它,就好像它是新的一样 - SAPUI5
Deleting a view and onclick opening it again, as if it is new - SAPUI5
我有一个多视图设置,一个主视图,然后是在某些操作后单击按钮打开的模块。
现在每次打开视图都会被我重置,但我想要完成的是,当视图离开时,它从核心消失并再次启动,就像第一次打开一样.
我不确定怎么做,我尝试了很多东西,none 按我的预期工作(.destroy()
、.removeAllContent()
、...)。
我是不是漏掉了某个功能,或者有什么方法可以实现吗?
一些代码:
index.js(第一次实例化View的方式,不是第二次调用)
module.exports.Partner = function(place) {
View = require('./app/js/suche.view');
Bearbeiten = require('./app/js/bearbeiten.view');
var ctrl = View.getController();
ctrl.setPlace(ctrl, place);
ctrl.setEditPlace(ctrl, place);
ctrl.setCreatePlace(ctrl, place);
sap.ui.getCore().byId('suche').placeAt(place);
sap.ui.getCore().byId('suche').byId('searchBtn').attachPress(ctrl.nummerSearch, ctrl);
};
控制器(如何调用视图和 index.js)
handlePartnerSuche : function(){
this.hideView(); //this is the main view
var p = require('bit-js-business-partner');
var partner_view = p.Partner('content');
p.setCallbackForSchliessen(this, this.callbackForSchliessen);
},
控制器(回调函数)
callbackForSchliessen: function(){
this.showView();
},
第二个视图(它是如何关闭的)
handleSchliessen : function () {
var p = this.getView('suche');
p.setVisible(false);
this.callbackMethodSchliessen.call(this.callbackCtrlSchliessen);
},
您提到由于公司限制您不能使用路由器机制 -- 我真的很想知道这些限制是什么;-) -- 并切换 visibility
相应视图的属性。
在这种情况下,我会在您将视图的可见性设置为可见的方法中触发 OData 服务,并将 ODataModel(重新)绑定到该视图。
从性能的角度来看,我不建议从核心破坏视图
我有一个多视图设置,一个主视图,然后是在某些操作后单击按钮打开的模块。
现在每次打开视图都会被我重置,但我想要完成的是,当视图离开时,它从核心消失并再次启动,就像第一次打开一样.
我不确定怎么做,我尝试了很多东西,none 按我的预期工作(.destroy()
、.removeAllContent()
、...)。
我是不是漏掉了某个功能,或者有什么方法可以实现吗?
一些代码:
index.js(第一次实例化View的方式,不是第二次调用)
module.exports.Partner = function(place) {
View = require('./app/js/suche.view');
Bearbeiten = require('./app/js/bearbeiten.view');
var ctrl = View.getController();
ctrl.setPlace(ctrl, place);
ctrl.setEditPlace(ctrl, place);
ctrl.setCreatePlace(ctrl, place);
sap.ui.getCore().byId('suche').placeAt(place);
sap.ui.getCore().byId('suche').byId('searchBtn').attachPress(ctrl.nummerSearch, ctrl);
};
控制器(如何调用视图和 index.js)
handlePartnerSuche : function(){
this.hideView(); //this is the main view
var p = require('bit-js-business-partner');
var partner_view = p.Partner('content');
p.setCallbackForSchliessen(this, this.callbackForSchliessen);
},
控制器(回调函数)
callbackForSchliessen: function(){
this.showView();
},
第二个视图(它是如何关闭的)
handleSchliessen : function () {
var p = this.getView('suche');
p.setVisible(false);
this.callbackMethodSchliessen.call(this.callbackCtrlSchliessen);
},
您提到由于公司限制您不能使用路由器机制 -- 我真的很想知道这些限制是什么;-) -- 并切换 visibility
相应视图的属性。
在这种情况下,我会在您将视图的可见性设置为可见的方法中触发 OData 服务,并将 ODataModel(重新)绑定到该视图。
从性能的角度来看,我不建议从核心破坏视图