记得在去年的一个产品开发中,公司老大要我们实现多标签选项卡的方式来呈现程序页面,当时没有成熟的主控框架,也没有好的技术文章可参考,凭着自己对需求文档上的描述理解,花了一周多时间自己吓整一通开发了一个系统主控框架出来。效果如下图:
关于这系统主控框架的开发我也通过两篇博文的方式分享,并提供了示例代码下载,有兴趣的朋友看直接查阅这两篇文章。
(一): 业务系统设计之二:系统主控设计(上)
(二): 业务系统设计之三:系统主控设计(下)
当时开发这一个东西确实耗了不少时间和精力,现在开发一个这样的东西可以很方便快速的实现了,Coolite Toolkit所提供的TabPanel就可以方便的解决上面这种需求。
TabPanel控件使用非常简单,但是功能却非常强大,它同MenuPanel、TreePanel一样提供了很多的集合属性,可以定制出丰富的应用。其中用得最多的就是他的Tabs属性,用于定义子标签选项,可参考下图所示:
其中content.html的代码如下代码片段,下图为运行效果截图:
TabPanel最灵活的是动态的创建子标签选项,想了解这个创建过程的实现原理请查阅我之前写的两篇文章(本文前面有文章连接),需要注意的是不能通过同步的事件驱动去创建,一但页面PostBack新创建的所有标签选项将被全部清除。如果一定要通过服务端后台代码去动态创建,可使用Coolite Toolkit所提供的AjaxEvent机制。
个人觉得通过同步方式创建页面总是会晃动一下,闪着让人很不爽。推荐通过客户端动态添加子标签选项的方式创建,TabPanel提供了相应的客户端API来完成这些操作。
通过JavaScript方法addTab()方法动态创建,三个参数分别为:TabPanel控件ID,新创建的Tab的ID,西创建的Tab所呈现的内容路径。
客户端创建的方式是纯Ext的操作方式,TabPanel提供了API可直接获取指定id的子Tab是否存在,使用这一功能就可以完美的处理互斥,以创建出唯一的Tab子标签选项。
TabPanel使用得多的就是用来处理多标签选项卡,另外多数时候是用作容器,其容器功能和Panel、Window等基本相同。就拿上一篇文章中创建的树做示例吧,现在需要将树显示在TabPanel的一个子标签选项里,可以直接调用TabPanel的客户端API方法addTab将一个存在的容器类型控件添加到TabPanel,使其成为TabPanel的子Tab。
本文就简单介绍于此,更多、更高、更高级、更适用的应用需要大家的努力挖掘,欢迎广大朋友排砖指正,相互交流学习。
关于这系统主控框架的开发我也通过两篇博文的方式分享,并提供了示例代码下载,有兴趣的朋友看直接查阅这两篇文章。
(一): 业务系统设计之二:系统主控设计(上)
(二): 业务系统设计之三:系统主控设计(下)
当时开发这一个东西确实耗了不少时间和精力,现在开发一个这样的东西可以很方便快速的实现了,Coolite Toolkit所提供的TabPanel就可以方便的解决上面这种需求。
TabPanel控件使用非常简单,但是功能却非常强大,它同MenuPanel、TreePanel一样提供了很多的集合属性,可以定制出丰富的应用。其中用得最多的就是他的Tabs属性,用于定义子标签选项,可参考下图所示:
其中content.html的代码如下代码片段,下图为运行效果截图:
<
html
xmlns
="http://www.w3.org/1999/xhtml"
>
< head >
< title ></ title >
< style type ="text/css" >
body{font-size:12px;}
</ style >
</ head >
< body >
TabPanel控件学习
</ body >
</ html >
< head >
< title ></ title >
< style type ="text/css" >
body{font-size:12px;}
</ style >
</ head >
< body >
TabPanel控件学习
</ body >
</ html >
TabPanel最灵活的是动态的创建子标签选项,想了解这个创建过程的实现原理请查阅我之前写的两篇文章(本文前面有文章连接),需要注意的是不能通过同步的事件驱动去创建,一但页面PostBack新创建的所有标签选项将被全部清除。如果一定要通过服务端后台代码去动态创建,可使用Coolite Toolkit所提供的AjaxEvent机制。
protected
void
CreataTab_Click(
object
sender, AjaxEventArgs e)
{
var tab = new Tab( " 通过AjaxEvent新增Tab " );
tab.TabIndex = short .Parse( " 11 " );
tab.ID = " tabID " ;
tab.AutoLoad.Url = " http://www.cnblogs.com " ;
tab.AutoLoad.NoCache = true ;
tab.AutoLoad.Mode = LoadMode.IFrame;
this .tabPanel.Tabs.Add(tab);
this .tabPanel.ActiveTab = tab;
}
{
var tab = new Tab( " 通过AjaxEvent新增Tab " );
tab.TabIndex = short .Parse( " 11 " );
tab.ID = " tabID " ;
tab.AutoLoad.Url = " http://www.cnblogs.com " ;
tab.AutoLoad.NoCache = true ;
tab.AutoLoad.Mode = LoadMode.IFrame;
this .tabPanel.Tabs.Add(tab);
this .tabPanel.ActiveTab = tab;
}
<
ext:Button
ID
="btnCreateTab"
runat
="server"
Text
="动态添加子标签选项"
>
< AjaxEvents >
< Click OnEvent ="CreataTab_Click" >
< EventMask ShowMask ="true" Msg ="正在加载" />
</ Click >
</ AjaxEvents >
</ ext:Button >
< AjaxEvents >
< Click OnEvent ="CreataTab_Click" >
< EventMask ShowMask ="true" Msg ="正在加载" />
</ Click >
</ AjaxEvents >
</ ext:Button >
个人觉得通过同步方式创建页面总是会晃动一下,闪着让人很不爽。推荐通过客户端动态添加子标签选项的方式创建,TabPanel提供了相应的客户端API来完成这些操作。
<
ext:Button
ID
="btnClient"
runat
="server"
Text
="添加Tab(Client)"
>
< Listeners >
< Click Handler ="addTab(#{tabPanel}, 'tabCnblogs', 'http://www.cnblogs.com');" />
</ Listeners >
</ ext:Button >
< Listeners >
< Click Handler ="addTab(#{tabPanel}, 'tabCnblogs', 'http://www.cnblogs.com');" />
</ Listeners >
</ ext:Button >
通过JavaScript方法addTab()方法动态创建,三个参数分别为:TabPanel控件ID,新创建的Tab的ID,西创建的Tab所呈现的内容路径。
<
script type
=
"
text/javascript
"
>
function addTab(tabPanel, id, url) {
var tab = tabPanel.getComponent(id);
if ( ! tab) {
tab = tabPanel.add({
id: id,
title: url,
closable: true ,
autoLoad: {
showMask: true ,
url: url,
mode: ' iframe ' ,
maskMsg: ' 正在加载 '
}
});
}
tabPanel.setActiveTab(tab);
}
< / script>
function addTab(tabPanel, id, url) {
var tab = tabPanel.getComponent(id);
if ( ! tab) {
tab = tabPanel.add({
id: id,
title: url,
closable: true ,
autoLoad: {
showMask: true ,
url: url,
mode: ' iframe ' ,
maskMsg: ' 正在加载 '
}
});
}
tabPanel.setActiveTab(tab);
}
< / script>
客户端创建的方式是纯Ext的操作方式,TabPanel提供了API可直接获取指定id的子Tab是否存在,使用这一功能就可以完美的处理互斥,以创建出唯一的Tab子标签选项。
TabPanel使用得多的就是用来处理多标签选项卡,另外多数时候是用作容器,其容器功能和Panel、Window等基本相同。就拿上一篇文章中创建的树做示例吧,现在需要将树显示在TabPanel的一个子标签选项里,可以直接调用TabPanel的客户端API方法addTab将一个存在的容器类型控件添加到TabPanel,使其成为TabPanel的子Tab。
Code
本文就简单介绍于此,更多、更高、更高级、更适用的应用需要大家的努力挖掘,欢迎广大朋友排砖指正,相互交流学习。
本文转自 beniao 51CTO博客,原文链接:http://blog.51cto.com/beniao/242636,如需转载请自行联系原作者