最近在做cms系统,使用ext遇到一个小问题,点击修改新闻后会新建一个tab标签,问题在于如果不关闭修改新闻的tab标签,再次选择其他新闻进行修改时,tab标签一直显示第一次打开的新闻内容。
一开始的思路是每次点击是刷新页面,找了好多方法终于能刷新的,但只是页面刷新内容并没有刷新。动态创建并刷新代码
var addtab = function(id,name,url){
var tab1 = tab.add({
id : id,
title : name,
layoutOnTabChange : true,
layout : 'fit',
html : '<iframe id="t_orders" src="'+url+'" height="100%" width="100%" frameborder="0" scrolling="auto"></iframe>',
closable : true,
listeners : {
activate: function(){
Ext.get('t_orders').dom.src = url;
}
}
});
tab.setActiveTab(tab1);
};
这个需要设置为全局变量,在子页面中就可以调用了。调用方法 window.parent.addtab(id,name,url);
这样写只是实现了刷新页面,并没有更改内容。问题在于add方法,如果存在id相同的tab ext会自动跳转不会再重新创建tab。于是想到了解决思路,如果不存在tab标签 那么就创建,如果存在那么就重新加载页面内容。代码如下
var addtab = function(id,name,url){
var cp = tab.getComponent(id);
if(!cp){
var tab1 = tab.add({
id : id,
title : name,
layoutOnTabChange : true,
layout : 'fit',
html : '<iframe id="t_orders" src="'+url+'" height="100%" width="100%" frameborder="0" scrolling="auto"></iframe>',
closable : true/*,
listeners : {
activate: function(){
Ext.get('t_orders').dom.src = url;
}
}*/
});
tab.setActiveTab(tab1);
} else{
Ext.get('t_orders').dom.src = url;
tab.setActiveTab(np);
}
};
问题解决了。
由于本人技术水平较低,如果文章中有什么错误,欢迎各位大神指出,谢谢!
不知道大神们有没有遇到过这种问题,又是如何解决的呢?