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

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

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

发布了34 篇原创文章 · 获赞 5 · 访问量 6万+
展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 大白 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览