ASP.Net巧用窗体母版页

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

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

 

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

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

 

巧用窗体母版项:

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

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

 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
<%@ 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文件为例):

 

?
1
2
3
4
5
<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样式就暂不说明):

 

 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<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,确定,生成的网页为:

 

 

?
1
2
3
4
5
<%@ 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中的代码为:

 

?
1
2
3
4
5
6
<%@ 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,代码为:

 

 

?
1
2
3
4
5
6
<%@ 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:content>

 

 

拓展:母版页嵌套母版页

当整个网站内的所有网页并不是这一种样式,而是一个大的网站分为几个栏目,每个栏目中网页的风格样式统一,这时候可以用母版页来嵌套母版页 :

 

现在再建立一个母版页(我在这里给它取名为“子母版页”),用它来嵌套上面的母版页test.Master,代码为:

 

?
1
2
3
4
5
6
7
8
9
10
11
<%@ Master Language= "C#" MasterPageFile= "~/test.Master" AutoEventWireup= "true" CodeBehind= "m_common.master.cs" Inherits= "Web.admin.m_common" %>
 
 
     
</asp:content>
 
     
     
          <%--此处为嵌套“子母版页”的各个网页的不同内容--%>
     </asp:contentplaceholder>
</asp:content>

注意,代码第一行的MasterPageFile=“~/test.Master”即要嵌套的母版页的地址,“~”为当前目录。

 

 

嵌套网页母版项的好处:

可以利用VisualStudio中的窗体母版页来将每个页面中相同的部分进行封装,在创建相同结构的网页时,便可以直接嵌套这个窗体母版页,避免了代码的重复,提高了代码的复用性;另外,如果要修改一个栏目甚至整个网站的风格,则只需修改母版页以及母版页中引入的<script>等文件,提高了代码的可维护性,充分体现了OOP的思想。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值