广

ASP.NET

  • IOS开发
  • android开发
  • PHP编程
  • JavaScript
  • ASP.NET
  • ASP编程
  • JSP编程
  • Java编程
  • 易语言
  • Ruby编程
  • Perl编程
  • AJAX
  • 正则表达式
  • C语言
  • 编程开发

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

    2018-04-08 09:03:38 次阅读 稿源:互联网
    广告

      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; }}

    一起学吧部分文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与一起学吧进行文章共享合作。

    广告
    广告
    广告