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,如需转载请自行联系原作者
相关文章
|
6月前
|
存储 开发框架 NoSQL
ASP.NET WEB——项目中Cookie与Session的用法
ASP.NET WEB——项目中Cookie与Session的用法
88 0
|
3月前
|
开发框架 JavaScript 前端开发
震撼!破解 ASP.NET 服务器控件 Button 执行顺序之谜,颠覆你的开发认知!
【8月更文挑战第16天】在ASP.NET开发中,通过Button控件实现先执行JavaScript再触后台处理的需求十分常见。例如,在用户点击按钮前需前端验证或提示,确保操作无误后再传递数据至后台深度处理。此过程可通过设置Button的`OnClientClick`属性调用自定义JavaScript函数完成验证;若验证通过,则继续触发后台事件。此外,结合jQuery也能达到相同效果,利用`__doPostBack`手动触发服务器端事件。这种方式增强了应用的交互性和用户体验。
44 8
|
2月前
|
开发框架 JavaScript 前端开发
|
3月前
|
开发框架 前端开发 .NET
闲话 ASP.NET Core 数据校验(二):FluentValidation 基本用法
闲话 ASP.NET Core 数据校验(二):FluentValidation 基本用法
|
5月前
|
JSON 前端开发 JavaScript
前端Ajax、Axios和Fetch的用法和区别笔记
前端Ajax、Axios和Fetch的用法和区别笔记
91 2
|
6月前
|
SQL 开发框架 JavaScript
分享33个ASP.NET电子商务源码和40个ASP.NET控件组件源码,总有一款适合您
分享33个ASP.NET电子商务源码和40个ASP.NET控件组件源码,总有一款适合您
84 0
|
6月前
|
SQL 开发框架 前端开发
ASP.NET WEB项目中GridView与Repeater数据绑定控件的用法
ASP.NET WEB项目中GridView与Repeater数据绑定控件的用法
82 0
|
6月前
|
开发框架 .NET
Asp.Net就业课堂之模板控件
Asp.Net就业课堂之模板控件
66 1
|
6月前
|
开发框架 .NET 数据安全/隐私保护
Asp.Net第二章服务器端控件
Asp.Net第二章服务器端控件
55 0
|
6月前
|
开发框架 JavaScript .NET
Asp.Net就业课之三验证控件
Asp.Net就业课之三验证控件
69 0