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

最近在做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);
	}
};
问题解决了。 

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值