ASP.NET中实现模版的动态加载(1)
来源:互联网 发布:上瘾网络剧台湾版在线 编辑:程序博客网 时间:2024/05/27 12:22
ASP.NET中,经常会使用到templates(模版)功能,比如在datagrid,datalist,repeater等控件中,使用templates,将会大大增强其功能。以往,我们一般是在设计程序时,就已经设置好控件中的模版是怎样的了。但是,有的时候,可能我们需要动态加载模版,比如,当你要求你的应用程序的界面风格随着用户的需求而变化时,你就需要到动态加载模版的功能了。但要注意的是,并不是所有的web控件都支持模版功能,而且要注意,哪些控件支持模版的哪些功能,下面简单列出了一些支持模版功能的控件:
Repeater控件,支持的模版有:
HeaderTemplate, FooterTemplate, ItemTemplate, AlternatingItemTemplate, SeperatorTemplate.
Datelist控件,支持的模版有:
HeaderTemplate, FooterTemplate, ItemTemplate, AlternatingItemTemplate, SeparatorTemplate, SelectedItemTemplate, EditItemTemplate.
Datagrid控件,支持的模版有:
HeaderTemplate, FooterTemplate, ItemTemplate, EditItemTemplate, Pager.
下面,我将以动态加载datalist控件的模版来说明如何动态加载模版:
首先来了解动态加载模版的原理。在.NET中,有templatecontrol类,这个类是page和usercontrol类的基类。它也同时定义了page和usercontrol类的基本功能。该类提供了两个方法:loadcontrol和loadtemplate。Loadcontrol方法装载来自外部文件的控件,并且返回usercontrol类对象。而loadtemplate方法加载来自外部文件的模版并且返回的是Itemplate对象。
Loadtemplate方法中,只有一个参数,参数值是外部模版文件的路径,并且返回itemplate对象。而datalist控件提供了一系列的属性,可以设置各种模版的属性,包括有AlternatingItemTemplate, EditItemTemplate, FooterTemplate, HeaderTemplate, ItemTemplate, SelectedItemTemplate, 和 SeperatorTemplate,在下文中,将会看到相关介绍。
接着,我们开始介绍例子,在示例程序中,是使用动态创建数据表和数据列的,并且将数据的创建封装到一个Db类中,好让读者进一步回顾如何动态创建数据表,数据列等,并没用从数据库中提取(当然,你也可以用传统的读取数据库的方法),
public class DB
{
public DB()
{ }
/// <summary>
/// Method returns a DataSet object filled with data
/// </summary>
public static DataSet GetDataSet()
{
//创建dataset和datatable
DataSet ds = new DataSet();
DataTable table = new DataTable("Records");
DataColumn col;
//增加一个列
col = new DataColumn();
col.DataType = System.Type.GetType("System.Int32");
col.ColumnName = "ID";
col.ReadOnly = true;
col.Unique = true;
table.Columns.Add(col);
col = new DataColumn();
col.DataType = System.Type.GetType("System.String");
col.ColumnName = "Name";
col.AutoIncrement = false;
col.Caption = "Name";
col.ReadOnly = false;
col.Unique = false;
table.Columns.Add(col);
col = new DataColumn();
col.DataType = System.Type.GetType("System.String");
col.ColumnName = "Address";
col.AutoIncrement = false;
col.Caption = "Address";
col.ReadOnly = false;
col.Unique = false;
table.Columns.Add(col);
//增加一条记录
DataRow row = table.NewRow();
row["ID"] = 1001;
row["Name"] = "Melanie Giard";
row["Address"] = "23rd Street, Park Road, NY City, NY";
table.Rows.Add(row);
row = table.NewRow();
row["ID"] = 1002;
row["Name"] = "Puneet Nehra";
row["Address"] = "3rd Blvd, Ashok Vihar, New Delhi";
table.Rows.Add(row);
row = table.NewRow();
row["ID"] = 1003;
row["Name"] = "Raj Mehta";
row["Address"] = "Nagrath Chowk, Jabalpur";
table.Rows.Add(row);
row = table.NewRow();
row["ID"] = 1004;
row["Name"] = "Max Muller";
row["Address"] = "25 North Street, Hernigton, Russia";
table.Rows.Add(row);
// Add DataTable to DataSet
ds.Tables.Add(table);
// Return DataSet
return ds;
}
}
接下来,我们首先创建若干个模版文件。我们先创建两组模版文件,每一组模版文件分别包含有header,footer,item,alternating item四个模版文件,保存成.ascx文件,这样,我们就有两类型风格的模版了,每类型风格的模版中都有自己的header,footer,item,alternating item子模版。下面为其中一个item模版文件,其他的类似。
文章出处:http://www.diybl.com/course/4_webprogram/asp.net/asp_netxl/200724/7711.html
- ASP.NET中实现模版的动态加载(1)
- ASP.NET中实现模版的动态加载
- ASP.NET中实现模版的动态加载
- ASP.NET中实现模版的动态加载
- ASP.NET中实现模版的动态加载
- ASP.NET中实现模版的动态加载
- ASP.NET中实现模版的动态加载
- ASP.NET中实现模版的动态加载
- ASP.NET中实现模版的动态加载
- ASP.NET中实现模版的动态加载
- ASP.NET中实现模版的动态加载
- ASP.NET中实现模版的动态加载
- ASP.NET中实现模版的动态加载
- ASP.NET中实现模版的动态加载
- ASP.NET中实现模版的动态加载
- ASP.NET中实现模版的动态加载
- ASP.NET中实现模版的动态加载
- ASP.NET中实现模版的动态加载
- 智能卡安全机制比较系列(一)CardOS
- 保存到txt文本文件中
- VSS 序列号
- JAVA 自带测试工具TOOLS——jps、jinfo、jstat、jmap、jconsole
- mwldsym2.exe: Undefined symbol: 'CDesC16ArrayFlat::CDesC16ArrayFlat(int) 构造问题
- ASP.NET中实现模版的动态加载(1)
- 解决快速启动中显示桌面消失问题
- 优化sql语句
- 智能卡安全机制比较系列(二)DS SmartCard
- 关于信贷规模与资本充足率的最新说法
- 学会这些你会更加成熟
- “用户请求取消当前的操作”的几种解决办法
- html table insert/delete rows(Table的行进行增加/删除)
- sql中查询日期的函数