Ext.Net学习笔记23:Ext.Net TabPanel用法详解

上面的图片中给出了TabPanel的一个效果图,我们来看一下代码:

<ext:TabPanel runat="server" ID="tabpanel1">
<Items>
<ext:Panel runat="server" ID="tab1" Title="Tab1" Html="第一个Tab">
</ext:Panel>
<ext:TreePanel runat="server" ID="tab2" Title="Tab2" Html="第二个Tab">
<Root>
<ext:Node Text="根节点" Expanded="true">
<Children>
<ext:Node Text="节点1" Expanded="true">
<Children>
<ext:Node Text="节点11" Leaf="true"></ext:Node>
<ext:Node Text="节点12" Leaf="true"></ext:Node>
</Children>
</ext:Node>
<ext:Node Text="节点2" Leaf="true"></ext:Node>
<ext:Node Text="节点3" Leaf="true"></ext:Node>
<ext:Node Text="节点4" Leaf="true"></ext:Node>
</Children>
</ext:Node>
</Root>
</ext:TreePanel>
</Items>
</ext:TabPanel>

这段代码中,我们在TabPanel中放了两个子项,一个是Panel,一个是TreePanel,每一个子项作为一个Tab展示在界面中。

我在代码中放了一个Panel和一个TreePanel的目的是想告诉大家,TabPanel中的子项需要继承自Panel,而TreePanel是继承自Panel的,由此可以联想到GridPanel、FormPanel等都可以作为TabPanel的子项来使用。

【题外话:在ExtJS中,出于效率的考虑,应该尽量减少items的嵌套,如果我们需要TabPanel的子项为TreePanel、GridPanel或FormPanel的时候,就没必要再将这些控件嵌套在Panel中】

异步加载Tab内容

异步加载仍然是出于性能的考虑,按需加载,当用户激活一个Tab标签的时候,我们再将这个标签的内容加载出来,从而避免加载未用到的数据。

接下来我们演示一下如何加载Tab2中的TreePanel

第一步,定义TabPanel,为Tab2添加Activate事件,用来处理激活操作:

<ext:TabPanel runat="server" ID="tabpanel1">
<Items>
<ext:Panel runat="server" ID="tab1" Title="Tab1" Html="第一个Tab">
</ext:Panel>
<ext:Panel runat="server" ID="tab2" Title="Tab2" Icon="Application">
<DirectEvents>
<Activate OnEvent="tab2_activate" Single="true">
<EventMask ShowMask="true" Target="This"></EventMask>
</Activate>
</DirectEvents>
</ext:Panel>
</Items>
</ext:TabPanel>

第二步,服务器端添加tab2_activate方法,用代码动态生成树,并添加到tab2中:

protected void tab2_activate(object sender, DirectEventArgs e)
{
TreePanel tree = createTree();
tree.AddTo(tab2);
} private TreePanel createTree()
{
TreePanel tree = new TreePanel();
tree.Root.Add(new Node() { Text = "根节点", Expanded = true });
tree.Root[0].Children.Add(new Node() { Text = "节点1", Expanded = true });
tree.Root[0].Children[0].Children.Add(new Node() { Text = "节点11", Leaf = true });
tree.Root[0].Children[0].Children.Add(new Node() { Text = "节点12", Leaf = true });
tree.Root[0].Children.Add(new Node() { Text = "节点2", Leaf = true });
tree.Root[0].Children.Add(new Node() { Text = "节点3", Leaf = true });
tree.Root[0].Children.Add(new Node() { Text = "节点4", Leaf = true }); return tree;
}

第三步,哈哈,没有第三步了,编译程序,刷新页面看看效果吧

当点击Tab2的标签后,首先看到的是加载提示,如下图:

加载完成以后才显示出来树节点。

将Tab标签绘制在底部

效果:

代码:

<ext:TabPanel runat="server" ID="tabpanel1" TabPosition="Bottom">
<Items>
...
</Items>
</ext:TabPanel>

通过TabPosition控制Tab的位置,默认为Top(顶部),另外还可以是Bottom(底部)、Left(左侧)和Right(右侧)。

在TabBar上添加自定义按钮

代码:

<TabBar>
<ext:ToolbarFill></ext:ToolbarFill>
<ext:Button runat="server" Icon="Add"></ext:Button>
<ext:Button runat="server" Icon="DatabaseSave"></ext:Button>
</TabBar>

TabScrollerMenu 插件

代码:

<Plugins>
<ext:TabScrollerMenu></ext:TabScrollerMenu>
</Plugins>

另外,还可以设置PageSize属性,用来控制每页显示的内容条数

Ext.Net学习笔记23:Ext.Net TabPanel用法详解的更多相关文章

  1. Linux防火墙iptables学习笔记(三)iptables命令详解和举例[转载]

     Linux防火墙iptables学习笔记(三)iptables命令详解和举例 2008-10-16 23:45:46 转载 网上看到这个配置讲解得还比较易懂,就转过来了,大家一起看下,希望对您工作能 ...

  2. (转)live555学习笔记10-h264 RTP传输详解(2)

    参考: 1,live555学习笔记10-h264 RTP传输详解(2) http://blog.csdn.net/niu_gao/article/details/6936108 2,H264 sps ...

  3. 学习笔记--Grunt、安装、图文详解

    学习笔记--Git安装.图文详解 安装Git成功后,现在安装Gruntjs,官网:http://gruntjs.com/ 一.安装node 参考node.js 安装.图文详解 (最新的node会自动安 ...

  4. SNMP学习笔记之SNMP 原理与实战详解

    原文地址:http://freeloda.blog.51cto.com/2033581/1306743 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法 ...

  5. Java8学习笔记(五)--Stream API详解[转]

    为什么需要 Stream Stream 作为 Java 8 的一大亮点,它与 java.io 包里的 InputStream 和 OutputStream 是完全不同的概念.它也不同于 StAX 对 ...

  6. JQuery学习笔记系列(一)----选择器详解

    笔者好长时间没有更新过博客园的笔记了,一部分原因是去年刚刚开始工作一段时间忙碌的加班,体会了一种每天加班到凌晨的充实感,之后闲暇时间了也因为自己懒惰没有坚持记笔记的习惯,现在重新拾起来. 借用古人的一 ...

  7. 【Java学习笔记之三十四】超详解Java多线程基础

    前言 多线程并发编程是Java编程中重要的一块内容,也是面试重点覆盖区域,所以学好多线程并发编程对我们来说极其重要,下面跟我一起开启本次的学习之旅吧. 正文 线程与进程 1 线程:进程中负责程序执行的 ...

  8. 【精选】Nginx模块Lua-Nginx-Module学习笔记(二)Lua指令详解(Directives)

    源码地址:https://github.com/Tinywan/Lua-Nginx-Redis Nginx与Lua编写脚本的基本构建块是指令. 指令用于指定何时运行用户Lua代码以及如何使用结果. 下 ...

  9. Redis 学习笔记2:redis.conf配置文件详解

    Redis 的配置文件位于 Redis 安装目录下,文件名为 redis.conf. 参数说明: 参数说明 redis.conf 配置项说明如下: 1. Redis默认不是以守护进程的方式运行,可以通 ...

随机推荐

  1. 安装Python

    因为Python是跨平台的,它可以运行在Windows.Mac和各种Linux/Unix系统上.在Windows上写Python程序,放到Linux上也是能够运行的. 要开始学习Python编程,首先 ...

  2. Countly在andoid和vps集成使用,开源的统计分析sdk

    这几天项目需要,简单研究了一下countly,说实话完全满足项目需要,比umeng这类产品干净多了. Countly Mobile Analytics 下面就讲一下android 集成的过程,以及 服 ...

  3. IEnumerable、IEnumerator与yield的学习

    我们知道数组对象可以使用foreach迭代进行遍历,同时我们发现类ArrayList和List也可以使用foreach进行迭代.如果我们自己编写的类也需要使用foreach进行迭代时该怎么办呢? IE ...

  4. MSSQLSERVER数据库- LEFT JOIN后面跟着WHERE竟变成内联 解决方法

    在LEFT JOIN后面跟着WHERE竟变成内联.百度后看到这个解决方法. 记录如下: select sre.*, co.description from subscribedratingelemen ...

  5. C#操作符的重载

    操作符也是可以重载的,先总结一下操作符的性质: 如我们所知,操作符在不同的情况下有不同的语义,具体取决于它所操作的类型.例如,操作符“+”在操作数值类型的时候意味着“加”,在操作字符串时意味着“连接” ...

  6. NPOI导出Excel示例

    摘要:使用开源程序NPOI导出Excel示例.NPOI首页地址:http://npoi.codeplex.com/,NPOI示例博客:http://tonyqus.sinaapp.com/. 示例编写 ...

  7. Flash Builder 创建CSS

    1.global 选择器将样式应用于所有控件 Ÿ 在 Flash Builder 中创建新MXML 文件并切换到设计模式 Ÿ 属性视图右侧的外观视图可更改外观 Flash Builder 自动创建CS ...

  8. Python标准库:内置函数reversed(seq)

    本函数是返回序列seq的反向訪问的迭代子. 样例: #reversed() for i in reversed([2, 3, 4, 5]): print(i, end = ',') 结果输出例如以下: ...

  9. ORACLE 毫秒与日期的相互转换

    毫秒转换为日期 SELECT TO_CHAR(1406538765000 / (1000 * 60 * 60 * 24) + TO_DATE('1970-01-01 08:00:00', 'YYYY- ...

  10. shell修改文件名(一)

    假如文件名是:time_filename.txt 改成filename_time.txt.例如20111111_me.txt改成me_201111111.txt要如何修改? #! /bin/sh fo ...