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

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

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvaHV5dXlhbmc2Njg4/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="">

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

因此在制作站点时,能够将这些共同的东西分离出来,放到“窗口母版页”中。在须要的时候嵌套就能够。

巧用窗口母版项:

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

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

<%@ Master Language="C#" AutoEventWireup="true" CodeBehind="test.master.cs" Inherits="Web.test1" %>
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title></title>
<asp:ContentPlaceHolder ID="head" runat="server">
</asp:ContentPlaceHolder>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:ContentPlaceHolder ID="contentPlaceHolder" runat="server"> </asp:ContentPlaceHolder>
</div>
</form>
</body>
</html>

2、在窗口母版页test.Master的<head>标记之间加入CSS、JS等引用(这里先仅仅加入CSS文件为例):

<head runat="server">
<link href="css/common.css" rel="stylesheet" /> <%--加入引用CSS文件--%>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title></title>
<asp:ContentPlaceHolder ID="head" runat="server">
</asp:ContentPlaceHolder>
</head>

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

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

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

<%@ Page Title="" Language="C#" MasterPageFile="~/common.Master" AutoEventWireup="true" CodeBehind="test2.aspx.cs" Inherits="Web.test2" %>
<asp:Content ID="Content1" ContentPlaceHolderID="head" runat="server">
</asp:Content>
<asp:Content ID="Content2" ContentPlaceHolderID="contentPlaceHolder" runat="server">
</asp:Content>

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

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

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

<%@ Page Title="" Language="C#" MasterPageFile="~/common.Master" AutoEventWireup="true" CodeBehind="test2.aspx.cs" Inherits="Web.test2" %>
<asp:Content ID="Content1" ContentPlaceHolderID="head" runat="server">
</asp:Content>
<asp:Content ID="Content2" ContentPlaceHolderID="contentPlaceHolder" runat="server">
<p>站点内容 站点内容 站点内容 站点内容…… </p>
</asp:Content>

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

<%@ Page Title="" Language="C#" MasterPageFile="~/common.Master" AutoEventWireup="true" CodeBehind="test2.aspx.cs" Inherits="Web.test2" %>
<asp:Content ID="Content1" ContentPlaceHolderID="head" runat="server">
</asp:Content>
<asp:Content ID="Content2" ContentPlaceHolderID="contentPlaceHolder" runat="server">
<p>站点内容1 站点内容1 站点内容1 站点内容1…… </p>
</asp:Content>

拓展:母版页嵌套母版页

当整个站点内的全部网页并非这一种样式。而是一个大的站点分为几个栏目。每一个栏目中网页的风格样式统一,这时候能够用母版页来嵌套母版页 :

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

<%@ Master Language="C#" MasterPageFile="~/test.Master" AutoEventWireup="true" CodeBehind="m_common.master.cs" Inherits="Web.admin.m_common" %>

<asp:Content ID="Content1" ContentPlaceHolderID="head" runat="server">

</asp:Content>

<asp:Content ID="Content2" ContentPlaceHolderID="contentPlaceHolder" runat="server">
<asp:ContentPlaceHolder ID="contentPlaceHolder_child" runat="server">
<%--此处为嵌套“子母版页”的各个网页的不同内容--%>
</asp:ContentPlaceHolder>
</asp:Content>

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

嵌套网页母版项的优点:

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

版权声明:本文博客原创文章,博客,未经同意,不得转载。

ASP.Net使用母版页窗的更多相关文章

  1. asp.net C#母版页和内容页事件排版载入顺序生命周期

    asp.net C#母版页和内容页事件排版载入顺序生命周期 关于ASP页面Page_Load发生在事件之前而导致的问题已经喜闻乐见,对于问题的解释也非常全面.可是怎样解决这个问题则较少有人说明,我就再 ...

  2. 2014-07-31 ASP.NET的母版页使用

    今天是在吾索实习的第17天.我在这天主要负责系统的骨架的搭建.首当其冲,要用的知识点就是ASP.NET母版页的使用了. ASP.NET的母版页有两种:一种是MasterPage,最常用也是最普通的母版 ...

  3. asp.net C#母版页和内容页事件排版加载顺序生命周期

    asp.net C#母版页和内容页事件排版加载顺序生命周期 关于ASP页面Page_Load发生在事件之前而导致的问题已经喜闻乐见,对于问题的解释也很全面,但是如何解决问题则较少有人说明,我就再 简单 ...

  4. ASP.NET 访问母版页元素总结

    第一种方法: 在母版页里面新建一个Label控件 <asp:ContentPlaceHolder id="ContentPlaceHolder1" runat="s ...

  5. Asp.Net 之 母版页中对控件ID的处理

    一.问题提出 由于总体排版和设计的需要,我们往往创建母版页来实现整个网站的统一性,最近我由于统一性的需要,把原来整个项目单独的页面全部套用了母版页.但是出现了一系列失效错误. 二. 抽象模型 由于整个 ...

  6. Asp.Net页面(母版页)加载顺序

    ASP.NET 母版页和内容页中的事件 母版页和内容页都可以包含控件的事件处理程序.对于控件而言,事件是在本地处理的,即内容页中的控件在内容页中引发事件,母版页中的控件在母版页中引发事件.控件事件不会 ...

  7. asp.net访问母版页控件方法

    一.使用多种方式为内容页加载母版页默认情况下是给单个内容页指定一个母版页加载,当多个内容页需加载到同一个母版页时,我们可以通过配置文件为多个内容页批量加载母版页,另外,还可以在PreInit事件中动态 ...

  8. ASP.NET在母版页或内容页上获取控件ID

    原本想给一个button添加一个confirm,不同的分数提示不同的信息(大于80合格,小于80不合格,提示是否提交),最开始用了button.Atribute.Add();但是它每次获取到的是lab ...

  9. ASP.NET MVC 母版页

    为什么使用母版页?为了整个站点样式统一,任何WEB应用程序都应该使用母版页.MVC框架中,有新的方式为母版页传递数据.       一个WEB应用程序可以包含多个母版页,母版页用于定义页面布局,它与普 ...

随机推荐

  1. Eclipse SDK构建J2EE开发环境

    鄙视官Java EE Developers 体积庞大的兄弟们可以提出自己的J2EE开发环境! 1.第一次去Eclipse官网下载Eclipse IDE 我使用的是:Eclipse IDE for Ja ...

  2. STL源代码分析--迭代摘要、迭代器失效汇总

    Vector 1.内部数据结构:连续存储,比如数组. 2.随机訪问每一个元素,所须要的时间为常量. 3.在末尾添加或删除元素所需时间与元素数目无关,在中间或开头添加或删除元素所需时间随元素数目呈线性变 ...

  3. sql语句like的使用方法

    在SQL结构化查询语言中,LIKE语句有着至关关键的数据. LIKE语句的语法格式是:select * from 表名 where 字段名 like 相应值(子串),它主要是针对字符型字段的,它的作用 ...

  4. 机器人操作系统 除了Android还有一个ROS(转)

    你知道市面上的机器人都采用了哪些操作系统吗? 估计大多数人给出的答案就是 Android 了.从市面上的产品来看,基于 Android 系统开发的机器人确实是主流,但是还有一种操作系统却鲜为人知,它叫 ...

  5. tc-SRM-626-DIV1-250

    枚举alice投掷骰子得到的结果的每一种情况极其数量. 枚举bob投掷骰子得到的结果的每一种情况极其数量. 然后枚举alice投掷骰子得到的结果的数量和bob投掷骰子比alice低的数量. 然后计算结 ...

  6. hibernate学习笔记(1)hibernate基本步骤

    hibernate基本步骤 1.创hibernate置对象 Configuration config = newConfiguration(); config.configure("hibe ...

  7. 应用ExcelPackage导出Excel

    前阵子工作需要,要实现从数据库中导出数据到Excel.老套路 先去百度上查阅资料,发现了以下几种方法: 1:将DataGrid控件中的数据导出Excel 2:将dataview导出excel 3:从网 ...

  8. Matlab中调用第三方Java代码

    搞了一天,才算搞定. 第一步:定位Matlab中Java环境的ext目录 新建一个M script文件,或者直接在Matlab的交互式命令行中输入: disp(java.lang.System.get ...

  9. 波折yosemite下载过程

    已经知道Yosemite正式宣布了这一消息,为了尽快有效地使用该系统尽可能.上学前把一个新的硬盘驱动器准备就绪-但不幸的是,我不知道是谁动手当天学校欠网关停电,我没有强迫受害者上课听老师讲废话(这是什 ...

  10. js中的open和showModalDialog

    一.window.open()支持环境: JavaScript1.0+/JScript1.0+/Nav2+/IE3+/Opera3+ 二.基本语法:window.open(pageURL,name,p ...