• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    ASP.Net巧用窗体母版页实例

    本文实例讲述了ASP.Net巧用窗体母版页的方法。分享给大家供大家参考。具体分析如下:

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

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

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

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

    巧用窗体母版项:

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

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

    复制代码 代码如下:
    %@ 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文件为例):

    复制代码 代码如下:
    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样式就暂不说明):
    复制代码 代码如下:
    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,确定,生成的网页为:

    复制代码 代码如下:
    %@ 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中的代码为:

    复制代码 代码如下:
    %@ 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,代码为:
    复制代码 代码如下:
    %@ 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,代码为:

    复制代码 代码如下:
    %@ 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的思想。

    希望本文所述对大家的asp.net程序设计有所帮助。

    您可能感兴趣的文章:
    • asp.net母版页如何使用
    • ASP.NET母版页基础知识介绍
    • ASP.NET中母版页和shtml实例入门
    • ASP.NET下母版页和内容页中的事件发生顺序整理
    • ASP.NET 2.0 中的创建母版页
    • 浅谈Asp.Net母版页的相关知识
    上一篇:.NET事件监听机制的局限与扩展分析
    下一篇:.net生成缩略图及水印图片时出现GDI+中发生一般性错误解决方法
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    ASP.Net巧用窗体母版页实例 ASP.Net,巧用,窗体,母版页,