·您现在的位置: 云翼网络 >> 文章中心 >> 网站建设 >> 网站建设开发 >> ASP.NET网站开发 >> ASP.Net巧用窗体母版页

ASP.Net巧用窗体母版页

作者:佚名      ASP.NET网站开发编辑:admin      更新时间:2022-07-23

asp.net巧用窗体母版页

背景:每个网页的基本框架结构类似:

浏览网站的时候会发现,好多网站中,每个网页的基本框架都是一样的,比如,最上面都是网站的标题,中间是内容,最下面是网站的版权、开发提供商等信息:

在这些网页中,表头、底部的样式和内容都是一样的,不同的只是中间的内容。

因此在制作网站时,可以将这些共同的东西分离出来,放到“窗体母版页”中,在需要的时候嵌套就可以。

巧用窗体母版项:

下面就开始行动(本文是以VisualStudio2013作为编程环境,可能在某些步骤与其他版本有所出入,请自行注意):

1、在项目中添加一Web窗体母版页test.Master:右键项目—添加—新建项—Web窗体母版页;

?
12345678910111213141516171819<%@ Master Language="C#" AutoEventWireup="true" CodeBehind="test.master.cs" Inherits="Web.test1" %><meta http-equiv="Content-Type" content="text/html; charset=utf-8"><title></title><asp:ContentPlaceHolder ID="head" runat="server"><form id="form1" runat="server"><div></asp:contentplaceholder></div></form><!--html>

2、在窗体母版页test.Master的标记之间添加CSS、JS等引用(这里先只添加CSS文件为例):

?
12345<link href="css/common.css" rel="stylesheet"> <%--添加引用CSS文件--%> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"><title></title></asp:contentplaceholder>

3、编辑窗体母版页test.Master,添加每个网页的公共内容(此处以网页布局为上图的布局为例,三个div的css样式就暂不说明):

?
123456789101112131415<form id="form1" runat="server"><div id="top"> <%--每个网页的公共样式:网页头部--%><h1>某某某网站</h1></div><div id="main"> <%--每个网页的不同样式:网页主体内容--%><%--此处为每个嵌套此母版的各个网页的不同内容--%></asp:contentplaceholder></div> <div id="footer"> <%--每个网页的公共样式:网页版权信息区--%><p>版权所有:******</p></div></form>

4、在每个网页中嵌套窗体母版页test.Master:右键项目—添加—新建项—包含母版页的Web窗体test.aspx,在选择母版页对话框中选择test.Master,确定,生成的网页为:

?
12345<%@ Page Title="\" Language="C#" MasterPageFile="~/common.Master" AutoEventWireup="true" CodeBehind="test2.aspx.cs" Inherits="Web.test2" %></asp:content></asp:content>

此时这个窗体test.aspx和母版页test.Master的运行效果是一样的,接下来就是加上每个网页中的不同的内容。

5、此时,网页test.aspx中ContentPlaceHolderID=“head”和ContentPlaceHolderID=“contentPlaceHolder”的就相当于母版页test.Master中对应的。所以假如每个网页都会有相同部分,就可以把相同部分写在母版页的相应位置,而将每个网页的不同内容写在ContentPlaceHolderID=“contentPlaceHolder”的中。

比如,第4步中,这个test.aspx已经嵌套了这个样式,它的主题内容为 “ 网站内容 网站内容 网站内容 网站内容…… ”,则test.aspx中的代码为:

?
123456<%@ Page Title="\" Language="C#" MasterPageFile="~/common.Master" AutoEventWireup="true" CodeBehind="test2.aspx.cs" Inherits="Web.test2" %></asp:content><p>网站内容 网站内容 网站内容 网站内容…… </p></asp:content>

假如我又建了一个名为test1.aspx的网页,除了与test1.aspx中的主体内容不一样之外,其他都一样,那么就可以让test1.aspx嵌套母版页test.Master,代码为:

?
123456<%@ Page Title="\" Language="C#" MasterPageFile="~/common.Master" AutoEventWireup="true" CodeBehind="test2.aspx.cs" Inherits="Web.test2" %></asp:content><p>网站内容1 网站内容1 网站内容1 网站内容1…… </p></asp:con