当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > ASP.NET中实现模版的动态加载

ASP.NET
ASP.NET立即上手教程(13)
ASP.NET立即上手教程(14)
Repeater控件分页例子
从文本文件读取行信息
Asp.Net 2.0数据库基本操作方法学习
url传递中文的解决方案
如何实现无刷新的DropdownList联动效果
将非模态对话框显示为模态对话框
微软新版开发工具VS 2008 beta2功能定案
c#.net函数列表
.Net FW中无法正确显示中文问题
ASP.NET中的doPostBack脚本函数实例
教你在asp.net中动态变更CSS
一个功能齐全的DataGrid分页例子
在ASP.NET程序中创建唯一序号
asp.net 2.0中用GRIDVIEW插入新记录
ASP.Net中保护自定义的服务器控件
在ASP.NET中跨页面实现多选
转换DataSet到普通xml的新法
ASP.NET中用healthMonitor属性用法

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-14   浏览: 87 ::
收藏到网摘: n/a

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类中,好让读者进一步回顾如何动态创建数据表,数据列等,并没用从数据库中提取(当然,你也可以用传统的读取数据库的方法),

publicclassDB
{
 publicDB()
 {}
 ///<summary>
 ///MethodreturnsaDataSetobjectfilledwithdata
 ///</summary>
 publicstaticDataSetGetDataSet()
 {
//创建dataset和datatable
DataSetds=newDataSet();
DataTabletable=newDataTable("Records");
DataColumncol;
//增加一个列
col=newDataColumn();
col.DataType=System.Type.GetType("System.Int32");
col.ColumnName="ID";
col.ReadOnly=true;
col.Unique=true;
table.Columns.Add(col);

col=newDataColumn();
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=newDataColumn();
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);

//增加一条记录
DataRowrow=table.NewRow();
row["ID"]=1001;
row["Name"]="MelanieGiard";
row["Address"]="23rdStreet,ParkRoad,NYCity,NY";
table.Rows.Add(row);
row=table.NewRow();
row["ID"]=1002;
row["Name"]="PuneetNehra";
row["Address"]="3rdBlvd,AshokVihar,NewDelhi";
table.Rows.Add(row);
row=table.NewRow();
row["ID"]=1003;
row["Name"]="RajMehta";
row["Address"]="NagrathChowk,Jabalpur";
table.Rows.Add(row);
row=table.NewRow();
row["ID"]=1004;
row["Name"]="MaxMuller";
row["Address"]="25NorthStreet,Hernigton,Russia";
table.Rows.Add(row);

//AddDataTabletoDataSet
ds.Tables.Add(table);
//ReturnDataSet
returnds;
 }
}

接下来,我们首先创建若干个模版文件。我们先创建两组模版文件,每一组模版文件分别包含有header,footer,item,alternatingitem四个模版文件,保存成.ascx文件,这样,我们就有两类型风格的模版了,每类型风格的模版中都有自己的header,footer,item,alternatingitem子模版。下面为其中一个item模版文件,其他的类似。

<%@ControlLanguage="VB"%>
<FONTface="verdana"color="green"size="2"><b>ID:</b>
<%#DataBinder.Eval(CType(Container,DataListItem).DataItem,"ID")%>
<b>Name:</b>
<%#DataBinder.Eval(CType(Container,DataListItem).DataItem,"Name")%>
<br>
<b>Address:</b>
<%#DataBinder.Eval(CType(Container,DataListItem).DataItem,"Address")%>
<p>
</FONT>

最后,我们开始创建应用程序,新建一个工程,添加两个按钮和一个datalist控件如下图

之后创建一个binddatagrid的方法,将dataset绑定到datalist控件中去,代码如下:privatevoidBindDataGrid()
{
 dtSet=DB.GetDataSet();
 DataList1.DataSource=dtSet.Tables[0].DefaultView;
 DataList1.DataBind();
}
privatevoidPage_Load(objectsender,System.EventArgse)
{
 if(!IsPostBack)
 {
BindDataGrid();
 }
}最后,分别为两个按钮的clcik事件添加代码,分别使用page.loadtemplate方法去加载我们已经写好的两套模版组中的模版,代码如下。privatevoidButton1_Click(objectsender,System.EventArgse)
{
 //Loadtemplates
 DataList1.AlternatingItemTemplate=
 Page.LoadTemplate("AltItemTempate.ascx");
 DataList1.ItemTemplate=Page.LoadTemplate("ItemTemplate.ascx");
 DataList1.HeaderTemplate=Page.LoadTemplate("HeadTemplate.ascx");
 DataList1.FooterTemplate=Page.LoadTemplate("FootTemplate.ascx");
 BindDataGrid();
}
privatevoidButton2_Click(objectsender,System.EventArgse)
{
 //Loadtemplates
 DataList1.AlternatingItemTemplate=Page.LoadTemplate("AltItemTempate2.ascx");
 DataList1.ItemTemplate=Page.LoadTemplate("ItemTemplate2.ascx");
 DataList1.HeaderTemplate=Page.LoadTemplate("HeadTemplate2.ascx");
 DataList1.FooterTemplate=Page.LoadTemplate("FootTemplate2.ascx");
 BindDataGrid();
}运行效果如下两图,当点不同的按钮时,动态装载不同的模版风格。