Asp.net Ajax Accordion控件的用法

简介:

Accordion,翻译过来是“手风琴、可折叠”的意思,微软Asp.net ajax提供了Accordion可折叠面板控件,方便用户在系统菜单、信息展示中使用,用户体验是相当的好啊。

这个控件允许定义多个面板,当用户选中一个面板时,其余面板都会折叠起来,只显示选中面板的内容。如果我说的不够清楚,请在这里查看示例:http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/Accordion/Accordion.aspx。此外,这个控件还支持数据绑定。

看完了示例,该知道这个控件功能好用了吧,下面就是用法了,先说说简单的用法,定义面板、设计面板,就是这么简单,下面给出一段代码,一看就能明白:

复制代码
< ajaxToolkit:Accordion ID ="MyAccordion" runat ="Server" SelectedIndex ="0" HeaderCssClass ="accordionHeader"
HeaderSelectedCssClass
="accordionHeaderSelected" ContentCssClass ="accordionContent"
AutoSize
="Limit" FadeTransitions ="true" TransitionDuration ="250" FramesPerSecond ="40"
Width
="700" Height ="200" RequireOpenedPane ="false" SuppressHeaderPostbacks ="true" >
< Panes >
< ajaxToolkit:AccordionPane HeaderCssClass ="accordionHeader" runat ="server" ContentCssClass ="accordionContent" >
< Header >
< span >1. 菜单一 </ span >
</ Header >
< Content >
< span >菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容 </ span >
</ Content >
</ ajaxToolkit:AccordionPane >
< ajaxToolkit:AccordionPane ID ="AccordionPane1" HeaderCssClass ="accordionHeader" HeaderSelectedCssClass ="accordionHeaderSelected"
runat
="server" ContentCssClass ="accordionContent" >
< Header >
< span >2. 菜单二 </ span >
</ Header >
< Content >
< span >菜单二的内容菜菜单二的内容菜菜单二的内容菜菜单二的内容菜菜单二的内容菜菜单二的内容菜菜单二的内容菜菜单二的内容菜菜单二的内容菜菜单二的内容菜菜单二的内容菜菜单二的内容菜菜单二的内容菜菜单二的内容菜菜单二的内容菜 </ span >
</ Content >
</ ajaxToolkit:AccordionPane >
< ajaxToolkit:AccordionPane ID ="AccordionPane2" HeaderCssClass ="accordionHeader" HeaderSelectedCssClass ="accordionHeaderSelected"
runat
="server" ContentCssClass ="accordionContent" >
< Header >
< span >3. 菜单三 </ span >
</ Header >
< Content >
< span >菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容菜单一的内容 </ span >
</ Content >
</ ajaxToolkit:AccordionPane >
</ Panes >
</ ajaxToolkit:Accordion >
复制代码

这个是不需要写后台代码的,拿去用就好了,既方便,又实用。

接下来说一下数据绑定的,在使用数据绑定时,首先需要设计好HeaderTemplate和ContentTemplate两个模板,然后在后台添加数据绑定代码就可以了。

模板设计和GridView的模板设计基本相同,下面是一段示例代码:

复制代码
< ajaxToolkit:Accordion ID ="BindAccordion" runat ="Server" HeaderCssClass ="accordionHeader"
HeaderSelectedCssClass
="accordionHeaderSelected" ContentCssClass ="accordionContent"
AutoSize
="None" FadeTransitions ="true" TransitionDuration ="250" FramesPerSecond ="40"
Width
="700" Height ="200" RequireOpenedPane ="false" SuppressHeaderPostbacks ="false" >
< HeaderTemplate >
< span > <% # DataBinder.Eval(Container.DataItem, " HeaderText " ) %> </ span >
</ HeaderTemplate >
< ContentTemplate >
< span > <% # DataBinder.Eval(Container.DataItem, " ContentText " ) %> </ span >
</ ContentTemplate >
</ ajaxToolkit:Accordion >
复制代码

有了这段代码,接下来就是后台的数据绑定了。能够接受的数据源不能使DataTable,不知道为什么,笔者试了DataView和List<>,都是可以的,唯独不能用DataTable,但这个没有关系,如果你的数据格式是DataTable,直接用它的DefaultView就可以了。下面是代码:

复制代码
// 第一种绑定方法
DataTable dt = new DataTable();
dt.Columns.Add( " HeaderText ");
dt.Columns.Add( " ContentText ");
dt.Rows.Add( new object[] { " 菜单一 ", " 内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容 " });
dt.Rows.Add( new object[] { " 菜单二 ", " 内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容 " });
dt.Rows.Add( new object[] { " 菜单三 ", " 内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容 " });
dt.Rows.Add( new object[] { " 菜单四 ", " 内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容 " });
dt.Rows.Add( new object[] { " 菜单五 ", " 内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容 " });
// 数据源需要是一个DataView,不知为何
this.BindAccordion.DataSource = dt.DefaultView;
this.BindAccordion.DataBind();

复制代码

上面是实用DataTable的方法,也是我们常常用到的。另外一个是List<>,为了方便起见,我们先定义一个类:

复制代码
class myItem
{
public string HeaderText
{ get; set; }
public string ContentText
{ get; set; }
}
复制代码

然后实用这个类的List来作为数据源:

复制代码
// 第二种绑定方法
List<myItem> itemList = new List<myItem>()
{
new myItem { HeaderText = " 菜单一 ", ContentText= " 内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容 " },
new myItem { HeaderText = " 菜单二 ", ContentText= " 内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容 " },
new myItem { HeaderText = " 菜单三 ", ContentText= " 内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容 " }
};
this.BindAccordion.DataSource = itemList;
this.BindAccordion.DataBind();
复制代码



本文转自齐师傅博客园博客,原文链接http://www.cnblogs.com/youring2/archive/2011/04/18/2020159.html,如需转载请自行联系原作者
相关文章
|
2月前
|
存储 开发框架 NoSQL
ASP.NET WEB——项目中Cookie与Session的用法
ASP.NET WEB——项目中Cookie与Session的用法
29 0
|
6月前
|
SQL 开发框架 前端开发
AJAX之四 Ajax控件工具集(下)
AJAX之四 Ajax控件工具集(下)
26 0
|
6月前
|
开发框架 前端开发 .NET
AJAX之四 Ajax控件工具集(中)
AJAX之四 Ajax控件工具集(中)
36 0
|
6月前
|
开发框架 前端开发 .NET
AJAX之四 Ajax控件工具集(上)
AJAX之四 Ajax控件工具集(上)
38 0
|
1月前
|
XML 开发框架 .NET
C# .NET面试系列八:ADO.NET、XML、HTTP、AJAX、WebService
## 第二部分:ADO.NET、XML、HTTP、AJAX、WebService #### 1. .NET 和 C# 有什么区别? .NET(通用语言运行时): ```c# 定义:.NET 是一个软件开发框架,提供了一个通用的运行时环境,用于在不同的编程语言中执行代码。 作用:它为多语言支持提供了一个统一的平台,允许不同的语言共享类库和其他资源。.NET 包括 Common Language Runtime (CLR)、基础类库(BCL)和其他工具。 ``` C#(C Sharp): ```c# 定义: C# 是一种由微软设计的面向对象的编程语言,专门为.NET 平台开发而创建。 作
173 2
|
2月前
|
SQL 开发框架 前端开发
ASP.NET WEB项目中GridView与Repeater数据绑定控件的用法
ASP.NET WEB项目中GridView与Repeater数据绑定控件的用法
32 0
|
4月前
|
开发框架 .NET 数据安全/隐私保护
Asp.Net第二章服务器端控件
Asp.Net第二章服务器端控件
27 0
|
4月前
|
开发框架 JavaScript .NET
Asp.Net就业课之三验证控件
Asp.Net就业课之三验证控件
44 0
|
4月前
|
开发框架 .NET
Asp.Net就业课堂之模板控件
Asp.Net就业课堂之模板控件
38 1
|
5月前
|
开发框架 前端开发 .NET
用ajax和asp.net实现智能搜索功能
用ajax和asp.net实现智能搜索功能
43 0