1. 程式人生 > >【ASP.NET】——母版頁

【ASP.NET】——母版頁

MasterPage母版頁

      在做web應用的時候,經常會遇到一些頁面之間有很多相同的顯示部分和行為,如果每個頁面都去重複編寫這些程式碼,是一個效率非常低的事情,因為提出了母版頁的概念,我們可以把多個頁面之間相同的行為和顯示部分放到母版頁中,只需要為每個頁面編寫不同的部分即可,這樣如果我們對公共部分需要變化僅僅更改母版頁就能達到目的。母版頁的檔案字尾名為.master,一個網站允許定義多個母版頁。

    母版頁不能單獨呈現,也就是我們不能在瀏覽器中直接輸入母版頁的URL地址進行訪問,必須依賴於內容頁才能呈現

新建一個使用當前使用母版頁的內容頁步驟如下:

(1)在網站專案或網站專案下的資料夾上點滑鼠右鍵,在出現的右鍵選單中“新增”——“新建項”

(2)在網站專案或網站專案下的資料夾下右擊新建,選擇“包含母版頁的web窗體”,這樣就完成了新增一個內容頁。

此時內容頁的程式碼如下:

<%@ Page Title="" Language="C#" MasterPageFile="~/栗子.Master" AutoEventWireup="true" CodeBehind="栗子.aspx.cs" Inherits="WebApplication2.栗子1" %>
<asp:Content ID="Content1" ContentPlaceHolderID="head" runat="server">
</asp:Content>
<asp:Content ID="Content2" ContentPlaceHolderID="ContentPlaceHolder1" runat="server">
</asp:Content>

在內容頁中有一個<asp:Content></asp:Content>標記,只有放在這個標記之間的程式碼執行時才會可見。

內容頁的常見屬性如下:

下面是一個內容頁訪問母版頁的例子:

母版頁程式碼:

<head id="Head1" 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>
            <table><tr><td>
                伺服器時間:<asp:Label ID="lbServerTime" runat="server" Text="">
                    </asp:Label></td></tr>
                <tr><td>
            <asp:ContentPlaceHolder ID="ContentPlaceHolder1" runat="server">
            </asp:ContentPlaceHolder>
                    </td></tr>
                <tr><td>
                    版本號:<asp:Label ID="lbCopyRight" runat="server" Text="">
                        </asp:Label></td></tr>
                </table>
        </div>
    </form>
</body>
</html>

內容頁的後臺程式碼:

protected void Page_Load(object sender, EventArgs e)
        {
            //其中lbserverTime是母版頁上的控制元件ID
            Label lbTimer = (Label)(this.Master.FindControl("lbServerTime"));
            lbTimer.Text = DateTime.Now.ToString("yyyy-MM-dd");
            Label lbCopyRight = (Label)(this.Master.FindControl("lbCopyRight"));
            lbCopyRight.Text = "Version 1.0";
        }

顯示效果如下:

母版頁的動態替換:

在程式設計開發中還可以根據條件動態替換內容頁所使用的母版頁。母版頁替換處理要在內容頁的初始化階段,也就是在內容頁的PreInit事件裡。

  //在這裡更換母版頁,不能在page_Load事件裡替換,會報異常
        protected override void OnPreInit(EventArgs e)
        {
            if (DateTime.Now.Millisecond % 2 == 0)
            {
                //注意“~/MasterPage.master”母版頁中必須有當前母版頁中一致的控制元件
                this.MasterPageFile = "~/栗子2.master";

            }
            base.OnInit(e);
        }