ext动态创建tab选项卡,刷新问题

最近在做cms系统,使用ext遇到一个小问题,点击修改新闻后会新建一个tab标签,问题在于如果不关闭修改新闻的tab标签,再次选择其他新闻进行修改时,tab标签一直显示第一次打开的新闻内容。ext动态创建tab选项卡,刷新问题_第1张图片

一开始的思路是每次点击是刷新页面,找了好多方法终于能刷新的,但只是页面刷新内容并没有刷新。动态创建并刷新代码

var addtab = function(id,name,url){
		var tab1 = tab.add({
			id : id,
			title : name,
		    layoutOnTabChange : true,
			layout : 'fit',
			html : '',
			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 : '',
			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);
	}
};
问题解决了。 

由于本人技术水平较低,如果文章中有什么错误,欢迎各位大神指出,谢谢!

不知道大神们有没有遇到过这种问题,又是如何解决的呢?

你可能感兴趣的:(ext动态创建tab选项卡,刷新问题)