问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

ExtJS TabPanel beforeremove beforeclose使用说明

发布网友 发布时间:2022-04-30 11:42

我来回答

2个回答

热心网友 时间:2022-05-17 02:11

当前系统使用Extjs做为前端框架,系统首页布局采用border方式,左边手风琴式的菜单栏,中间区域为TabPanel容器,点击左边菜单栏内的对应菜单在中间区域添加对应的Panel,Panel嵌入添加的gridview;
当前问题是,想在用户关闭时弹出对话框提示用户,根据用户选择是否销毁当前页面(Panel),或是隐藏当前Panel,保存临时数据;
查看Extjs
API文档,对添加的panel监听beforeclose事件
主要代码如下
中间区域部分:
复制代码
代码如下:
//centerPanel
centerPanel
=
new
Ext.TabPanel({
id:
'centerPnl'
,
region:
'center'
,
border:
false
,
iconCls:
'tabs'
,
enableTabScroll:
true
,
items:
[{
title:
'首页'
,
autoScroll:
true
}]
,
defaults:
{
autoScroll:
true
}
});增加一个新的Panelfunction
addCMUAMS_LogTab()
{
activeCMUAMS_LogTab
=
centerPanel.add({
id:
'CMUAMS_LogShowAll'
,
title:
'系统日志'
,
iconCls:
'tabs'
,
closable:
true
,
bodyStyle:
'padding:10px'
,
items:
CMUAMS_LogGrid
,
listeners:
{
beforeclose:TabCloseConfirm
}
})
activeCMUAMS_LogTab.show();
}
但是这样的话,情况如下:

Panel在'beforeclose'前已经关闭了;后来上网Google,查阅资料,忽然想到TabePanel作为容器是不是要在其处先进行事件拦截?于是修改中间区域部分代码如下//centerPanel
复制代码
代码如下:
centerPanel
=
new
Ext.TabPanel({
id:
'centerPnl'
,
region:
'center'
,
border:
false
,
iconCls:
'tabs'
,
enableTabScroll:
true
,
items:
[{
title:
'首页'
,
autoScroll:
true
}]
,
defaults:
{
autoScroll:
true
}
//首先监听beforeremove事件
,
listeners:
{
beforeremove:
function(ct,component
)
{
return
false;
}
}
});
再运行,查看效果:

搞定想必点击Panel上的关闭按钮时,应该是首先执行的所在TabPanel容器的Remove事件,然后再执行Panel自身的Close事件;项目赶时间,没过多时间深究了,小弟也是对JS和Extjs了解不深,有路过熟知的朋友望告知真实原因。
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
瑞安市塘下航达汽车电器配件厂怎么样? 意尔康公司总部地址在哪里 I only wish to face the sea, with spring blossoms是什么意思 征信五级分类是什么?被纳入黑名单有什么影响? 你好,如果诈骗分子利用你隐私视频和盗取你的通讯录好友威胁你要钱的话... ...对方有我的私密照片还有通讯录,要求我给他五千,要不然就发我家人,我... ...现在已经一个月没有性生活了。但是她平时对我很好 是怎么了?_百度... 女人半年没有性生活正常吗 谁能用英语给我写一段游戏里面的征婚启事? 征婚启事用英文怎么说? ExtJS TabPanel获取组件问题 extjs的tabpanel中两个panel分别加载两个grid怎么实现 ExtJS tabpanel 动态添加 panel tab时 怎么用影优尽优开抖音直播 ExtJs 中的tabPanel中如何加入gridPanel并且让它的宽高自适应求高手解答... 如何遍历ExtJS的TabPanel并获得每个Tab中的包含的输入框的值_百度知... extjs tabpanel 指定tab的内容 extjs中如何令Ext.tab.Panel像div一样,定位浮动在页面 关于Oracle用sqlldr导数据的问题! extjs tabpanle问题 中国封建社会开始于( ) 我国封建社会起止时间,都城,重要君王,朝代,建立者 中国封建社会有多少个朝代,起止时间 欧洲. 中国封建社会的起止时间 中国封建社会从什么时候算起 中国奴隶社会,封建社会经历了哪些朝代?起止时间 封建社会的起止时间? 封建社会什么时候开始? 中国的封建社会大约从什么时候开始到什么时候结束? 封建社会何时开始,何时结束? extjs TabPanel 选中某个TAB页标签,该TAB页标签填充红色,内字体变白色... 在Extjs中,我想通过点击一个按钮,然后在一个TabPanel中加入一个Panel组 ... extjs 分页遇到问题 Extjs 的Ext.Panel 使用按钮问题 Ext的TabPanel的标签页如何动态的显示 电气图上KMO是什么意思 kmo & Bartlett test是什么 kmo化学符号是什么意思 kmo值在什么范围内,因子分析才是有效的? 亚威KMO是什么意思? KMO系数是什么?怎么测算? 雅诗兰黛瓶子底部字母kmo代表什么意思 什么是kmo统计量?有什么意义? 雅诗兰黛小棕瓶kmo和ryo什么区别 KMO和巴特利特检验中自由度是什么 kmo显著性为0是什么意思 kmo3是什么化学物质? 用spss软件做的因子分析得到的结论都是什么意思 初学SPSS,请问效度检验中的这四个表怎么看,是什么意思? 请问在作KMO检验与Bartlett球形检验怎么输入变量啊,我不知道要输入哪些变量,选择变量是什么啊?SPSS17.0