gpt4 book ai didi

extjs - 如何从窗口获取数据到主屏幕

转载 作者:行者123 更新时间:2023-12-01 10:32:30 25 4
gpt4 key购买 nike

在某些 Ajax 调用成功后,我将打开一个窗口并将响应附加到该窗口。这是我的代码。

success: function (response) {
var data = Ext.decode(response.data);
var window = Ext.widget('win');
window.data = data;
window.show();
},

现在我正在做一些操作,所有的人工数据都在窗口对象中可用。保存后我关闭窗口。在 Parent 上,当我尝试像这样访问时,我没有获得任何值(value)。如何处理这个。

someFunction : function(){
var window = Ext.widget('win');
window.data ; // Fail (No data available).
}

最佳答案

success()someFunction() 中的 Window 对象与 Ext.widget 不同,将在两者中创建一个单独的实例职能。所以数据不会被持久化。要保留数据,您可以使用 configviewModel

我已经根据您的场景创建了一个示例代码,以使用对特定 View 及其 Controller 具有全局性作用的配置在窗口关闭时保留数据。

Ext.application({
name : 'Fiddle',

launch : function() {
Ext.create("Ext.form.Panel",{
renderTo: Ext.getBody(),
config: {
win: Ext.widget('window'), //if we store window, on close we loose it
data: "" //it will persist, so this can be used
},
items: [
{
xtype: 'button',
text: 'call',
handler: function(){
var me = this;
Ext.Ajax.request({
url: 'data1.json',

success: function(response, opts) {
var data = Ext.decode(response.responseText);
var window = me.up().config.win;
me.up().config.data = data;
window.data = data;
window.show();
},

failure: function(response, opts) {
console.log('server-side failure with status code ' + response.status);
}
});
}
}, {
xtype: 'button',
text: 'Get Value',
handler: function(){
console.log(this.up().config.win.data);
console.log(this.up().config.data);
}
}
]
});
}
});

这里第一个按钮的处理程序将代表您的 ajax 调用成功,第二个按钮的处理程序代表您的someFunction

这里我保留了两个配置,win 和 data。 win 是一个窗口对象,它会在关闭时被销毁,所以我们不能使用它。第二个是数据,它是一个普通变量,除非相应的 View 被销毁,否则它将被持久化。所以你可以使用第二个配置。

你可以找到工作 fiddle here .

关于extjs - 如何从窗口获取数据到主屏幕,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57921358/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com