十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
这篇文章主要讲解了“ASP.NET怎么实现模板”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“ASP.NET怎么实现模板”吧!
站在用户的角度思考问题,与客户深入沟通,找到城东网站设计与城东网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:网站制作、做网站、企业官网、英文网站、手机端网站、网站推广、域名申请、虚拟主机、企业邮箱。业务覆盖城东地区。
ASP.NET模板基本的实现方法
在以前(或许现在),当我们在做WEB项目的时候,常常会用到一些共用文件,比如整页的顶部(页眉),左部(导航),底部(页脚)等等一些共用的HTML,ASP等文件,即便如此,我们也需要预先为这些文件做好框架的样式(一般是用table吧?!没几个会用DIV吧),以组合(include)这些文件得到一个完整的页面,这些共用文件的组合,这里假设把它定义成模板(尽管模板的真正含义可能远不止此)。即便如此,当我们项目中整个框架发生变动时,我们不得修改原先通过table等等一些HTML标签定义好的每个需要这样模板的页面,而这样的工作尽管可以通过ctrl+c和ctrl+v来完成,但同时工作量也是巨大的,耗时的。一下是ASP.NET模板基本的实现方法
发展
在ASP.NET里,使用的是面向对象的开发模式,可以这么理解---每个页面都是一个从SystemWeb.UI.Page继承的Class,这个类给我们提供了一些诸如缓存,表示,应答,请求等服务(说是方法也行)。通过面向对象的方法是不是有比用include更好的解决方法呢?当然,答案是肯定的。
实现
记得有句名言叫“任何问题都可以通过加入一个中间层来实现”,举个很简单的例子,我们常常使用Façade这个模式降低系统的耦合度,而我们又为什么要使用设计模式呢?主要是用来减小耦合提高复用的。
从所有的ASPX页面都由SystemWeb.UI.Page继承而来这点上来看,我们只需在ASPX和SystemWeb.UI.Page之间加入一层,写一个我们自己的Class就可以使问题变得简单化,而在.NET框架中,允许用户自定义HTML代码(这点可以参考Web User Controls),这样解决问题的雏形就出来了。
我们加入的一个中间层,该自定类继承System.Web.UI.Page这个基类,下面给出自定类的代码:
PageBase.cs
publicclassPageBase:System.Web.UI.Page
{
publicstringPageTitle="测试模板";
protectedoverridevoidRender(System.Web.UI.HtmlTextWriterwriter)
{
writer.Write(@"
<metahttp-equivmetahttp-equiv='Content-Type'content='text/html;charset=gb2312'>
"+this.PageTitle+""); writer.Write(@"
<tablebordertableborder='0'width='680'>
<tdwidthtdwidth='160'bgcolor='#006699'align='center'><fontcolorfontcolor='
#FFFFFF'><ahrefahref='index.aspx'>首页<tdcolspantdcolspan='2'width='520'>广告条
<tdwidthtdwidth='160'valign='top'>
导航
<
ahrefahref='newContact.aspx'>添加联系人查找联系人
<tdwidthtdwidth='10'>
<tdwidthtdwidth='510'>
");
base.Render(writer);
writer.Write(@"
<tdwidthtdwidth='100%'colspan='3'> ");
页脚}
}
上面的PageBase.cs就是我们的自定类,这样,我们在其他ASPX页面中就可以直接继承PageBase这个类,而非System.Web.UI.Page,下面分别是index.aspx和newContact.aspx的代码(分别包含index.aspx.cs和newContact.aspx.cs):
Index.aspx
<%@Pagelanguage="c#"Codebehind="index.aspx.cs"AutoEventWireup=
"false"Inherits="wab.index"%><formidformid="index"method="post"runat="server">
<asp:DataGrididasp:DataGridid="contacts"runat="server"Width=
"492px"Height="104px">
index.aspx.cs(继承自定义类PageBase)
publicclassindex:PageBase
{
protectedSystem.Web.UI.WebControls.DataGridcontacts;
privatevoidPage_Load(objectsender,System.EventArgse)
{
//在此处放置用户代码以初始化页面
}
#regionWebFormDesignergeneratedcode
overrideprotectedvoidOnInit(EventArgse)
{
//
//CODEGEN:该调用是ASP.NETWeb窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}
///
///设计器支持所需的方法-不要使用代码编辑器修改
///此方法的内容。
///
privatevoidInitializeComponent()
{
this.Load+=newSystem.EventHandler(this.Page_Load);
}
#endregion
}
newContact.aspx
<%@Pagelanguage="c#"Codebehind="newContact.aspx.cs"AutoEventWireup=
"false"Inherits="wab.newContact"%><formidformid="newContact"method="post"runat="server">
<
FONTfaceFONTface="宋体">名子<asp:TextBoxidasp:TextBoxid="TextBox1"runat="server">
<
FONTfaceFONTface="宋体">姓氏<asp:TextBoxidasp:TextBoxid="TextBox2"runat="server">
<asp:Buttonidasp:Buttonid="Button1"runat="server"Text="Button">
newContact.aspx.cs(继承自定类PageBase)
publicclassnewContact:PageBase
{
protectedSystem.Web.UI.WebControls.TextBoxTextBox1;
protectedSystem.Web.UI.WebControls.ButtonButton1;
protectedSystem.Web.UI.WebControls.TextBoxTextBox2;
privatevoidPage_Load(objectsender,System.EventArgse)
{
}
#regionWebFormDesignergeneratedcode
overrideprotectedvoidOnInit(EventArgse)
{
//
//CODEGEN:该调用是ASP.NETWeb窗体设计器所必需的
//
InitializeComponent();
base.OnInit(e);
}
///
///设计器支持所需的方法-不要使用代码编辑器修改
///此方法的内容。
///
privatevoidInitializeComponent()
{
this.Load+=newSystem.EventHandler(this.Page_Load)
}
#endregion
}
感谢各位的阅读,以上就是“ASP.NET怎么实现模板”的内容了,经过本文的学习后,相信大家对ASP.NET怎么实现模板这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是创新互联,小编将为大家推送更多相关知识点的文章,欢迎关注!