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,如需转载请自行联系原作者
相关文章
|
4月前
|
开发框架 JavaScript 前端开发
震撼!破解 ASP.NET 服务器控件 Button 执行顺序之谜,颠覆你的开发认知!
【8月更文挑战第16天】在ASP.NET开发中,通过Button控件实现先执行JavaScript再触后台处理的需求十分常见。例如,在用户点击按钮前需前端验证或提示,确保操作无误后再传递数据至后台深度处理。此过程可通过设置Button的`OnClientClick`属性调用自定义JavaScript函数完成验证;若验证通过,则继续触发后台事件。此外,结合jQuery也能达到相同效果,利用`__doPostBack`手动触发服务器端事件。这种方式增强了应用的交互性和用户体验。
52 8
|
7月前
|
开发框架 前端开发 JavaScript
ASP.NET AJAX使用方法概述(三)
ASP.NET AJAX使用方法概述(三)
56 1
|
2月前
|
开发者 Windows
.NET 开源扁平化、美观的 C/S 控件库
【10月更文挑战第23天】介绍了三款适用于 .NET 平台的开源扁平化、美观的 C/S 控件库:MaterialSkin 采用 Google Material Design 风格,适合现代感界面;Krypton Toolkit 提供丰富控件,界面易于定制;Fluent Ribbon Control Suite 模仿 Office 界面,适合复杂功能应用。每款控件库均附有示例代码及 GitHub 链接。
winform .net6 和 framework 的图表控件,为啥项目中不存在chart控件,该如何解决?
本文讨论了在基于.NET 6和.NET Framework的WinForms项目中添加图表控件的不同方法。由于.NET 6的WinForms项目默认不包含Chart控件,可以通过NuGet包管理器安装如ScottPlot等图表插件。而对于基于.NET Framework的WinForms项目,Chart控件是默认存在的,也可以通过NuGet安装额外的图表插件,例如LiveCharts。文中提供了通过NuGet添加图表控件的步骤和截图说明。
winform .net6 和 framework 的图表控件,为啥项目中不存在chart控件,该如何解决?
|
2月前
|
C# Android开发 iOS开发
一组.NET MAUI绘制的开源控件 - AlohaKit
一组.NET MAUI绘制的开源控件 - AlohaKit
|
3月前
|
开发框架 JavaScript 前端开发
|
4月前
|
开发框架 前端开发 .NET
闲话 ASP.NET Core 数据校验(二):FluentValidation 基本用法
闲话 ASP.NET Core 数据校验(二):FluentValidation 基本用法
|
3月前
|
开发框架 前端开发 JavaScript
ASP.NET MVC 教程
ASP.NET 是一个使用 HTML、CSS、JavaScript 和服务器脚本创建网页和网站的开发框架。
48 7
|
3月前
|
存储 开发框架 前端开发
ASP.NET MVC 迅速集成 SignalR
ASP.NET MVC 迅速集成 SignalR
75 0
|
4月前
|
开发框架 前端开发 .NET
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
56 0