ddc
联网
平面设计 画册 VI欣赏 包装 CG-插画 搜索 个人网页 Alexa排名 CSS 建站资源 下载专区 JS特效 品牌服装 服装院校 专题欣赏 SEO 图标欣赏 专题
网站建设 域名注册 网站建设 虚拟主机 广州网站设计 域名注册 广州网站建设 上海网站建设 虚拟主机 广州网页设计 虚拟主机 域名注册 acg王国 ACG玩家 品牌设计 上海网站建设
求创科技
网站建设
中国互联
素材出售
中国设计秀
中资源
当前位置:网络学院首页 >> 编程开发 >> .net >> ASP.NET中实现模版的动态加载

ASP.NET中实现模版的动态加载 (1)

来源:中国设计秀    作者:straw    点击:55     加入收藏    发表评论
0
顶一下
关键字:模版 ASP.NET

      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;

}}

[1] [2]
2008-08-29 10:50:00    出处:中国设计秀cnwebshow.com
Google
网站地图 | 关于我们 | 联系我们 | 网站建设 | 广告服务 | 版权声明 | 免责声明 | 网站公告 | 友情链接 | 留言 | 旧版入口