主版頁面與網站導覽 (C#)
用戶易記網站的其中一個常見特性是,其具有一致的全網站版面配置和瀏覽配置。 本教學課程將探討如何跨所有可輕鬆更新的頁面建立一致的外觀和風格。
簡介
用戶易記網站的其中一個常見特性是,其具有一致的全網站版面配置和瀏覽配置。 ASP.NET 2.0 引進了兩項新功能,可大幅簡化全網站版面配置和流覽配置的實作:主版頁面和網站導覽。 主版頁面可讓開發人員建立具有指定可編輯區域的全網站範本。 此範本接著可以套用至網站中的 ASP.NET 頁面。 這類 ASP.NET 頁面只需要提供主版頁面指定之可編輯區域的內容,主版頁面中所有其他標記在使用主版頁面的所有 ASP.NET 頁面上都相同。 此模型可讓開發人員定義並集中整個網站的版面配置,藉此更輕鬆地在所有可更新的頁面建立一致的外觀和風格。
網站導覽系統提供一種機制,讓頁面開發人員定義網站地圖,以及以程式設計方式查詢該網站地圖的 API。 新的導覽 Web 會控制 Menu、TreeView 和 SiteMapPath,讓您輕鬆地在通用導覽使用者介面元素中轉譯所有或部分網站地圖。 我們將使用預設網站導覽提供者,這表示我們的網站地圖會以 XML 格式的檔案定義。
為了說明這些概念,並讓我們的教學課程網站更容易使用,讓我們在此課程中定義全網站版面配置、實作網站地圖,以及新增導覽UI。 在本教學課程結束時,我們將有一個完善網站設計來建置我們的教學課程網頁。
圖 1:本教學課程的結束結果 (按兩下以檢視完整大小的影像)
步驟 1:建立主版頁面
第一個步驟是建立網站的主版頁面。 現在,我們的網站只包含具類型的 DataSet (Northwind.xsd
、資料夾) 、BLL 類別 (ProductsBLL.cs
、CategoriesBLL.cs
等等,包括App_Code
資料夾) 、資料庫 NORTHWND.MDF
App_Data
(、資料夾) 、組態檔 Web.config
() ,以及 () 的 CSS 樣式表單檔案Styles.css
App_Code
。 我已從前兩個教學課程中清除這些示範使用 DAL 和 BLL 的頁面和檔案,因為我們將在未來的教學課程中更詳細地重新探索這些範例。
圖 2:專案中的檔案
若要建立主版頁面,請以滑鼠右鍵按兩下 方案總管 中的專案名稱,然後選擇 [新增專案]。 然後從樣本清單中選取主版頁面類型,並將其命名為 Site.master
。
圖 3:將新的主版頁面新增至網站 (按兩下即可檢視完整大小的影像)
在主版頁面中定義全網站版面配置。 您可以使用 [設計] 檢視,並新增您需要的任何 [版面配置] 或 [Web] 控件,也可以手動在 [來源] 檢視中手動新增標記。 在主版頁面中,我使用 級聯樣式表 來定位和樣式,以及外部檔案 Style.css
中定義的 CSS 設定。 雖然您無法從如下所示的標記中分辨,但會定義 CSS 規則,讓導覽 <div>
的內容絕對定位,使其出現在左側,且寬度固定為 200 圖元。
Site.master
<%@ Master Language="C#" AutoEventWireup="true"
CodeFile="Site.master.cs" Inherits="Site" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title>Working with Data Tutorials</title>
<link href="Styles.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="wrapper">
<form id="form1" runat="server">
<div id="header">
<span class="title">Working with Data Tutorials</span>
<span class="breadcrumb">
TODO: Breadcrumb will go here...</span>
</div>
<div id="content">
<asp:contentplaceholder id="MainContent"
runat="server">
<!-- Page-specific content will go here... -->
</asp:contentplaceholder>
</div>
<div id="navigation">
TODO: Menu will go here...
</div>
</form>
</div>
</body>
</html>
主版頁面會定義靜態頁面配置,以及可使用主版頁面的 ASP.NET 頁面編輯的區域。 這些內容可編輯區域是由 ContentPlaceHolder 控件表示,這可以在內容 <div>
中看見。 我們的主版頁面有單一 ContentPlaceHolder (MainContent
) ,但主版頁面可能有多個 ContentPlaceHolders。
在上方輸入標記時,切換至 [設計] 檢視會顯示主版頁面的版面配置。 使用此主版頁面的任何 ASP.NET 頁面都會有這個統一的版面配置,並能夠指定區域的標記 MainContent
。
圖 4:主版頁面,透過 [設計視圖] 檢視時 (按兩下即可檢視完整大小的影像)
步驟 2:將首頁新增至網站
定義主版頁面后,我們即可新增網站的 ASP.NET 頁面。 讓我們從新增 Default.aspx
,我們的網站首頁開始。 以滑鼠右鍵按兩下 方案總管中的專案名稱,然後選擇 [新增專案]。 從樣本清單中挑選 [Web 表單] 選項,並將檔案 Default.aspx
命名為 。 此外,請核取 [選取主版頁面] 複選框。
圖 5:新增 Web 窗體,核取 [選取主版頁面] 複選框 (按兩下即可檢視完整大小的影像)
按兩下 [確定] 按鈕之後,系統會要求我們選擇這個新主版頁面 ASP.NET 應該使用哪一個主版頁面。 雖然您可以在專案中有多個主版頁面,但我們只有一個主版頁面。
圖 6:選擇此 ASP.NET 頁面應使用的主版頁面, (按兩下即可檢視完整大小的影像)
挑選主版頁面之後,新的 ASP.NET 頁面將包含下列標記:
Default.aspx
<%@ Page Language="C#" MasterPageFile="~/Site.master" AutoEventWireup="true"
CodeFile="Default.aspx.cs" Inherits="_Default" Title="Untitled Page" %>
<asp:Content ID="Content1" ContentPlaceHolderID="MainContent"
Runat="Server">
</asp:Content>
在 @Page
指示詞中,會參考主版頁面檔案 (MasterPageFile="~/Site.master"
) ,而 ASP.NET 頁面的標記包含主版頁面中定義之每個 ContentPlaceHolder 控件的 Content 控件,其中控件 ContentPlaceHolderID
會將 Content 控件對應至特定的 ContentPlaceHolder。 [內容] 控件是放置您想要出現在對應 ContentPlaceHolder 中之標記的位置。 將 @Page
指示詞的 Title
屬性設定為 Home,並將一些歡迎的內容新增至內容控制項:
Default.aspx
<%@ Page Language="C#" MasterPageFile="~/Site.master" AutoEventWireup="true"
CodeFile="Default.aspx.cs" Inherits="_Default" Title="Home" %>
<asp:Content ID="Content1" ContentPlaceHolderID="MainContent"
Runat="Server">
<h1>Welcome to the Working with Data Tutorial Site</h1>
<p>This site is being built as part of a set of tutorials that
illustrate some of the new data access and databinding features in
ASP.NET 2.0 and Visual Web Developer.</p>
<p>Over time, it will include a host of samples that
demonstrate:</p>
<ul>
<li>Building a DAL (data access layer),</li>
<li>Using strongly typed TableAdapters and DataTables</li>
<li>Master-Detail reports</li>
<li>Filtering</li>
<li>Paging,</li>
<li>Two-way databinding,</li>
<li>Editing,</li>
<li>Deleting,</li>
<li>Inserting,</li>
<li>Hierarchical data browsing,</li>
<li>Hierarchical drill-down,</li>
<li>Optimistic concurrency,</li>
<li>And more!</li>
</ul>
</asp:Content>
Title
指示詞中的 @Page
屬性可讓我們從 ASP.NET 頁面設定頁面的標題,即使<title>
元素是在主版頁面中定義也一樣。 我們也可以使用 以程式設計方式 Page.Title
設定標題。 另請注意,主版頁面對樣式表單的參考 (,例如 Style.css
) 會自動更新,因此無論 ASP.NET 頁面相對於主版頁面的目錄為何,它們都能在任何 ASP.NET 頁面中運作。
切換至 [設計] 檢視,我們可以看到頁面在瀏覽器中的外觀。 請注意,在 [ASP.NET] 頁面的 [設計] 檢視中,只有內容可編輯區域是可編輯主版頁面中定義的非 ContentPlaceHolder 標記呈現灰色。
圖 7:[ASP.NET] 頁面的設計檢視會顯示可編輯和不可編輯的區域 (按兩下即可檢視完整大小的影像)
Default.aspx
當瀏覽器瀏覽頁面時,ASP.NET 引擎會自動合併頁面的主版頁面內容和 ASP。NET 的內容,並將合併的內容轉譯成傳送至要求瀏覽器的最終 HTML。 當主版頁面的內容更新時,使用此主版頁面的所有 ASP.NET 頁面,都會在下次要求時,將其內容重新合併到新的主版頁面內容。 簡單地說,主版頁面模型允許定義單一頁面版面配置範本, (主版頁面) 其變更會立即反映在整個網站中。
將其他 ASP.NET 頁面新增至網站
讓我們花點時間將額外的 ASP.NET 頁面存根新增至最終會保存各種報告示範的網站。 總共會有 35 個以上的示範,因此,而不是建立所有存根頁面,讓我們只建立前幾個。 由於也會有許多類別的示範,為了更妥善地管理示範,請新增類別的資料夾。 目前新增下列三個資料夾:
BasicReporting
Filtering
CustomFormatting
最後,新增新的檔案,如圖 8 中的 方案總管 所示。 新增每個檔案時,請記得核取 [選取主版頁面] 複選框。
圖 8:新增下列檔案
步驟 2:建立網站地圖
管理由少數頁面組成的網站,其中一項挑戰是讓訪客直接瀏覽網站。 若要從 開始,必須定義網站的導覽結構。 接下來,此結構必須轉譯為可導覽的使用者介面元素,例如功能表或階層連結。 最後,需要維護並更新整個程式,因為新頁面會新增至網站,並移除現有的頁面。 在 ASP.NET 2.0 之前,開發人員自行建立網站的導覽結構、維護它,以及將它轉譯為可導覽的使用者介面元素。 不過,透過 ASP.NET 2.0,開發人員可以利用非常彈性的內建網站導覽系統。
ASP.NET 2.0 網站導覽系統提供一種方法,讓開發人員定義網站地圖,然後透過程式設計 API 存取此資訊。 ASP.NET 隨附網站地圖提供者,預期網站地圖數據會以特定方式格式化的 XML 檔案來儲存。 但是,由於網站導覽系統是以 提供者模型 為基礎而建置,因此可以擴充以支援串行化網站地圖資訊的替代方式。 Jeff Prosise 的文章:您正在等候的 SQL 網站地圖提供者會示範如何建立網站地圖提供者,以將網站地圖儲存在 SQL Server 資料庫中;另一個選項是根據文件系統結構建立網站地圖提供者。
不過,在本教學課程中,讓我們使用隨附於 ASP.NET 2.0 的默認網站地圖提供者。 若要建立網站地圖,只要以滑鼠右鍵按兩下 方案總管中的專案名稱,選擇 [新增專案],然後選擇 [網站地圖] 選項。 將名稱保留為 Web.sitemap
,然後按兩下 [新增] 按鈕。
圖 9:將網站地圖新增至您的專案, (按兩下即可檢視完整大小的影像)
網站地圖檔案是 XML 檔案。 請注意,Visual Studio 會為網站地圖結構提供 IntelliSense。 網站地圖檔案必須具有 <siteMap>
節點作為其根節點,該節點必須精確包含一個 <siteMapNode>
子元素。 該第一個項目 <siteMapNode>
接著可以包含任意數目的子代 <siteMapNode>
專案。
定義網站地圖以模擬檔案系統結構。 也就是說,針對這三個資料夾的每一個 <siteMapNode>
新增元素,以及這些資料夾中每個 ASP.NET 頁面的子 <siteMapNode>
元素,如下所示:
Web.sitemap
<?xml version="1.0" encoding="utf-8" ?>
<siteMap xmlns="http://schemas.microsoft.com/AspNet/SiteMap-File-1.0" >
<siteMapNode url="~/Default.aspx" title="Home" description="Home">
<siteMapNode title="Basic Reporting"
url="~/BasicReporting/Default.aspx"
description="Basic Reporting Samples">
<siteMapNode url="~/BasicReporting/SimpleDisplay.aspx"
title="Simple Display"
description="Displays the complete contents
of a database table." />
<siteMapNode url="~/BasicReporting/DeclarativeParams.aspx"
title="Declarative Parameters"
description="Displays a subset of the contents
of a database table using parameters." />
<siteMapNode url="~/BasicReporting/ProgrammaticParams.aspx"
title="Setting Parameter Values"
description="Shows how to set parameter values
programmatically." />
</siteMapNode>
<siteMapNode title="Filtering Reports"
url="~/Filtering/Default.aspx"
description="Samples of Reports that Support Filtering">
<siteMapNode url="~/Filtering/FilterByDropDownList.aspx"
title="Filter by Drop-Down List"
description="Filter results using a drop-down list." />
<siteMapNode url="~/Filtering/MasterDetailsDetails.aspx"
title="Master-Details-Details"
description="Filter results two levels down." />
<siteMapNode url="~/Filtering/DetailsBySelecting.aspx"
title="Details of Selected Row"
description="Show detail results for a selected item in a GridView." />
</siteMapNode>
<siteMapNode title="Customized Formatting"
url="~/CustomFormatting/Default.aspx"
description="Samples of Reports Whose Formats are Customized">
<siteMapNode url="~/CustomFormatting/CustomColors.aspx"
title="Format Colors"
description="Format the grid s colors based
on the underlying data." />
<siteMapNode
url="~/CustomFormatting/GridViewTemplateField.aspx"
title="Custom Content in a GridView"
description="Shows using the TemplateField to
customize the contents of a field in a GridView." />
<siteMapNode
url="~/CustomFormatting/DetailsViewTemplateField.aspx"
title="Custom Content in a DetailsView"
description="Shows using the TemplateField to customize
the contents of a field in a DetailsView." />
<siteMapNode url="~/CustomFormatting/FormView.aspx"
title="Custom Content in a FormView"
description="Illustrates using a FormView for a
highly customized view." />
<siteMapNode url="~/CustomFormatting/SummaryDataInFooter.aspx"
title="Summary Data in Footer"
description="Display summary data in the grids footer." />
</siteMapNode>
</siteMapNode>
</siteMap>
網站地圖會定義網站的導覽結構,這是描述網站各種區段的階層。 <siteMapNode>
中的每個Web.sitemap
元素都代表網站導覽結構中的區段。
圖 10:網站地圖代表階層式導覽結構, (按兩下即可檢視完整大小的影像)
ASP.NET 會透過 .NET Framework的 SiteMap 類別公開網站地圖的結構。 這個類別具有 CurrentNode
屬性,它會傳回使用者目前正在流覽之區段的相關信息; RootNode
屬性會在網站地圖) 中傳回網站地圖 (首頁的根目錄。 和 RootNode
屬性都會CurrentNode
傳回 SiteMapNode 實例,其具有 、ParentNode
ChildNodes
、NextSibling
、 PreviousSibling
等屬性,允許逐步執行網站地圖階層。
步驟 3:根據網站地圖顯示功能表
在 ASP.NET 2.0 中存取資料可以透過程序設計方式完成,例如在 ASP.NET 1.x 中,或透過新的 數據源控件以宣告方式存取數據。 有數個內建數據源控件,例如 SqlDataSource 控件、用於存取關係資料庫數據、ObjectDataSource 控制件、從類別存取數據等等。 您甚至可以建立自己的 自定義數據源控件。
數據源控件可作為您 ASP.NET 頁面與基礎數據之間的 Proxy。 為了顯示數據源控件的擷取數據,我們通常會將另一個Web控件新增至頁面,並將其系結至數據源控件。 若要將 Web 控件系結至數據源控件,只要將 Web 控件的 DataSourceID
屬性設定為數據源控件的 ID
屬性值即可。
為了協助處理網站地圖的數據,ASP.NET 包含 SiteMapDataSource 控件,這可讓我們將 Web 控件系結至網站的網站地圖。 TreeView 和 Menu 有兩個 Web 控件通常用來提供導覽用戶介面。 若要將網站地圖數據系結至這兩個控件的其中一個,只要將 SiteMapDataSource 新增至頁面,以及已據此設定其屬性的 DataSourceID
TreeView 或 Menu 控件即可。 例如,我們可以使用下列標記,將功能表控件新增至主版頁面:
<div id="navigation">
<asp:Menu ID="Menu1" runat="server"
DataSourceID="SiteMapDataSource1">
</asp:Menu>
<asp:SiteMapDataSource ID="SiteMapDataSource1" runat="server" />
</div>
為了更精細地控制發出的 HTML,我們可以將 SiteMapDataSource 控件系結至 Repeater 控制項,如下所示:
<div id="navigation">
<ul>
<li><asp:HyperLink runat="server" ID="lnkHome"
NavigateUrl="~/Default.aspx">Home</asp:HyperLink></li>
<asp:Repeater runat="server" ID="menu"
DataSourceID="SiteMapDataSource1">
<ItemTemplate>
<li>
<asp:HyperLink runat="server"
NavigateUrl='<%# Eval("Url") %>'>
<%# Eval("Title") %></asp:HyperLink>
</li>
</ItemTemplate>
</asp:Repeater>
</ul>
<asp:SiteMapDataSource ID="SiteMapDataSource1"
runat="server" ShowStartingNode="false" />
</div>
SiteMapDataSource 控件會一次傳回網站地圖階層一個層級,從根網站地圖節點 (首頁開始,在我們的網站地圖) 中,下一個層級 (基本報告、篩選報表和自定義格式設定) 等等。 將 SiteMapDataSource 系結至 Repeater 時,它會列舉傳回的第一個層級,並針對該第一個層級中的每個SiteMapNode
實例具現化 ItemTemplate
。 若要存取 的特定屬性SiteMapNode
,我們可以使用 Eval(propertyName)
,這是我們取得 HyperLink 控件每個 SiteMapNode
Url
和 Title
屬性的方式。
上述 Repeater 範例會轉譯下列標記:
<li>
<a href="/Code/BasicReporting/Default.aspx">Basic Reporting</a>
</li>
<li>
<a href="/Code/Filtering/Default.aspx">Filtering Reports</a>
</li>
<li>
<a href="/Code/CustomFormatting/Default.aspx">
Customized Formatting</a>
</li>
這些網站地圖節點 (基本報告、篩選報表和自定義格式設定) 組成要轉譯之網站地圖 的第二 層,而不是第一個層級。 這是因為 SiteMapDataSource 的 ShowStartingNode
屬性設定為 False,導致 SiteMapDataSource 略過根網站地圖節點,而改為從傳回網站地圖階層中的第二個層級開始。
若要顯示基本報告、篩選報表和自訂格式 SiteMapNode
設定的子系,我們可以將另一個重複項新增至初始 Repeater 的 ItemTemplate
。 第二個 Repeater 將會系結至 SiteMapNode
實例的 ChildNodes
屬性,如下所示:
<asp:Repeater runat="server" ID="menu" DataSourceID="SiteMapDataSource1">
<ItemTemplate>
<li>
<asp:HyperLink runat="server"
NavigateUrl='<%# Eval("Url") %>'>
<%# Eval("Title") %></asp:HyperLink>
<asp:Repeater runat="server"
DataSource='<%# ((SiteMapNode) Container.DataItem).ChildNodes %>'>
<HeaderTemplate>
<ul>
</HeaderTemplate>
<ItemTemplate>
<li>
<asp:HyperLink runat="server"
NavigateUrl='<%# Eval("Url") %>'>
<%# Eval("Title") %></asp:HyperLink>
</li>
</ItemTemplate>
<FooterTemplate>
</ul>
</FooterTemplate>
</asp:Repeater>
</li>
</ItemTemplate>
</asp:Repeater>
這兩個重複項會導致下列標記 (某些標記已移除,以求簡潔) :
<li>
<a href="/Code/BasicReporting/Default.aspx">Basic Reporting</a>
<ul>
<li>
<a href="/Code/BasicReporting/SimpleDisplay.aspx">
Simple Display</a>
</li>
<li>
<a href="/Code/BasicReporting/DeclarativeParams.aspx">
Declarative Parameters</a>
</li>
<li>
<a href="/Code/BasicReporting/ProgrammaticParams.aspx">
Setting Parameter Values</a>
</li>
</ul>
</li>
<li>
<a href="/Code/Filtering/Default.aspx">Filtering Reports</a>
...
</li>
<li>
<a href="/Code/CustomFormatting/Default.aspx">
Customized Formatting</a>
...
</li>
使用 Rachel Andrew書籍中選擇的 CSS 樣式:CSS Anthology:101 基本秘訣、訣竅、& 駭客, <ul>
和 <li>
元素的樣式,讓標記產生下列視覺輸出:
圖 11:由兩個重複器和一些 CSS 組成的功能表
此菜單位於主版頁面中,並系結至 中 Web.sitemap
定義的網站地圖,這表示網站地圖的任何變更都會立即反映在使用 Site.master
主版頁面的所有頁面上。
停用 ViewState
所有 ASP.NET 控件都可以選擇性地將其 狀態保存到檢視狀態,這會串行化為轉譯 HTML 中的隱藏表單域。 控件會使用檢視狀態來記住其跨回傳的程式設計變更狀態,例如系結至數據 Web 控件的數據。 雖然檢視狀態允許跨回傳記住資訊,但它會增加必須傳送給用戶端的標記大小,而且如果未密切監視,可能會導致嚴重的頁面高載。 數據 Web 控制項特別是 GridView 對於將數十個額外的標記新增至頁面特別麻煩。 雖然這類增加可能會對寬頻或內部網路使用者而言微不足道,但檢視狀態可能會為撥號使用者的來回行程增加數秒。
若要查看檢視狀態的影響,請瀏覽瀏覽器中的頁面,然後在 Internet Explorer 中檢視網頁所傳送的來源 (,移至 [檢視] 功能表,然後選擇 [來源] 選項) 。 您也可以開啟 頁面追蹤 ,以查看頁面上每個控件所使用的檢視狀態配置。 檢視狀態資訊會串行化為名為 __VIEWSTATE
的隱藏表單域,位於 <div>
開頭 <form>
標記之後的 元素中。 只有在使用 Web 窗體時,才會保存檢視狀態;如果您的 ASP.NET 頁面未在其 <form runat="server">
宣告式語法中包含 ,則呈現的標記中不會有 __VIEWSTATE
隱藏的表單域。
主 __VIEWSTATE
版頁面所產生的表單域會在頁面產生的標記中新增大約 1,800 個字節。 這個額外的閃爍主要是由於 Repeater 控件所致,因為 SiteMapDataSource 控制件的內容會保存到檢視狀態。 雖然額外的 1,800 個字節看起來可能不太令人興奮,但在使用具有許多字段和記錄的 GridView 時,檢視狀態可能會因 10 個以上的因素而輕鬆停留。
藉由將 EnableViewState
屬性設定為 false
,即可停用頁面或控件層級的檢視狀態,藉此減少轉譯標記的大小。 由於數據 Web 控制項的檢視狀態會保存跨回傳系結至數據 Web 控件的數據,因此停用數據 Web 控制項的檢視狀態時,數據必須系結至每個回傳。 在 ASP.NET 1.x 版中,此責任會落在頁面開發人員的承擔上;不過,使用 ASP.NET 2.0 時,數據 Web 控件會視需要重新系結至其數據源控件。
若要減少頁面的檢視狀態,讓我們將 Repeater 控制件的 EnableViewState
屬性設定為 false
。 這可以透過 Designer 中的 屬性視窗,或在 [來源] 檢視中以宣告方式完成。 進行這項變更之後,Repeater 的宣告式標記看起來應該像這樣:
<asp:Repeater runat="server" ID="menu" DataSourceID="SiteMapDataSource1"
EnableViewState="False">
<ItemTemplate>
... <i>ItemTemplate contents omitted for brevity</i> ...
</ItemTemplate>
</asp:Repeater>
在此變更之後,頁面的轉譯檢視狀態大小只會壓縮為 52 個字節,以檢視狀態大小節省 97% 的費用! 在本系列教學課程中,我們預設會停用數據 Web 控件的檢視狀態,以減少轉譯標記的大小。 在大部分的範例中, EnableViewState
屬性會設定為 false
,而且不會提及。 唯一的時間檢視狀態將會討論在必須啟用的情況下,數據 Web 控件才能提供其預期的功能。
步驟 4:新增階層鏈接流覽
若要完成主版頁面,讓我們將階層鏈接流覽 UI 元素新增至每個頁面。 階層連結可快速向用戶顯示其站台階層中的目前位置。 在 ASP.NET 2.0 中新增階層連結很容易,只要將 SiteMapPath 控制項新增至頁面即可;不需要任何程序代碼。
針對我們的網站,將此控件新增至標頭 <div>
:
<span class="breadcrumb">
<asp:SiteMapPath ID="SiteMapPath1" runat="server">
</asp:SiteMapPath>
</span>
階層鏈接會顯示使用者正在網站地圖階層中流覽的目前頁面,以及該網站地圖節點的「上階」,一路前往網站地圖 (首頁的根目錄) 。
圖 12:階層鏈接會顯示網站地圖階層中的目前頁面及其上階
步驟 5:新增每個區段的預設頁面
網站中的教學課程分成不同的類別基本報告、篩選、自定義格式等等,其中包含每個類別的資料夾,以及對應教學課程,作為該資料夾內的 ASP.NET 頁面。 此外,每個資料夾都包含一個 Default.aspx
頁面。 針對此默認頁面,讓我們顯示目前章節的所有教學課程。 也就是說,在 Default.aspx
BasicReporting
資料夾中,我們有 、 DeclarativeParams.aspx
和ProgrammaticParams.aspx
的連結SimpleDisplay.aspx
。 同樣地,我們可以使用 SiteMap
類別和數據 Web 控制件,根據中 Web.sitemap
定義的網站地圖來顯示這項資訊。
讓我們再次使用重複程式來顯示未排序的清單,但這次我們將顯示教學課程的標題和描述。 由於要完成此作業的標記和程式代碼必須針對每個 Default.aspx
頁面重複,因此我們可以將此 UI 邏輯封裝在 使用者控件中。 在名為 UserControls
的網站中建立名為 的資料夾,並將 新增至名為 SectionLevelTutorialListing.ascx
的 Web 使用者控件類型新專案,並新增下列標記:
圖 13:將新的 Web 使用者控制項新增至 UserControls
資料夾, (按兩下即可檢視完整大小的影像)
SectionLevelTutorialListing.ascx
<%@ Control Language="CS" AutoEventWireup="true"
CodeFile="SectionLevelTutorialListing.ascx.cs"
Inherits="UserControls_SectionLevelTutorialListing" %>
<asp:Repeater ID="TutorialList" runat="server" EnableViewState="False">
<HeaderTemplate><ul></HeaderTemplate>
<ItemTemplate>
<li><asp:HyperLink runat="server"
NavigateUrl='<%# Eval("Url") %>'
Text='<%# Eval("Title") %>'></asp:HyperLink>
- <%# Eval("Description") %></li>
</ItemTemplate>
<FooterTemplate></ul></FooterTemplate>
</asp:Repeater>
SectionLevelTutorialListing.ascx.cs
using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
public partial class UserControls_SectionLevelTutorialListing : UserControl
{
protected void Page_Load(object sender, EventArgs e)
{
// If SiteMap.CurrentNode is not null,
// bind CurrentNode ChildNodes to the GridView
if (SiteMap.CurrentNode != null)
{
TutorialList.DataSource = SiteMap.CurrentNode.ChildNodes;
TutorialList.DataBind();
}
}
}
在先前的 Repeater 範例中,我們會以宣告方式將數據系結 SiteMap
至 Repeater; SectionLevelTutorialListing
不過,使用者控件會以程式設計方式執行。 在事件處理程式中 Page_Load
,會進行檢查,以確保此頁面的URL對應至網站地圖中的節點。 如果這個使用者控件用於沒有對應 <siteMapNode>
項目的頁面中, SiteMap.CurrentNode
將會傳回 null
,而且不會將任何數據系結至 Repeater。 假設我們有 CurrentNode
,我們會將其 ChildNodes
集合系結至 Repeater。 由於已設定網站地圖,因此 Default.aspx
每個區段中的頁面都是該區段內所有教學課程的父節點,因此此程式代碼會顯示所有區段教學課程的連結和描述,如以下螢幕快照所示。
建立這個重複項之後,請開啟Default.aspx
每個資料夾中的頁面,移至 [設計] 檢視,然後直接將 [使用者控件] 從 方案總管 拖曳到您想要顯示教學課程列表的設計介面上。
圖 14:使用者控件已新增至 Default.aspx
(按兩下即可檢視全大小影像)
圖 15:列出基本報告教學課程 (按兩下即可檢視完整大小的影像)
摘要
定義網站地圖並完成主版頁面之後,我們現在有數據相關教學課程的一致版面配置和瀏覽配置。 不論我們新增至網站的頁面數目為何,更新全網站版面配置或網站導覽資訊都是快速且簡單的程序,因為這項資訊會集中化。 具體來說,頁面配置資訊是在主版頁面 Site.master
和 中的網站地圖中 Web.sitemap
定義。 我們不需要撰寫 任何 程式代碼來達成此全網站版面配置和瀏覽機制,而且我們會在 Visual Studio 中保留完整的 WYSIWYG 設計工具支援。
已完成數據存取層和商業規則層,並已定義一致的頁面配置和網站導覽,我們已準備好開始探索常見的報告模式。 在接下來的三個教學課程中,我們將探討顯示從 GridView、DetailsView 和 FormView 控件中 BLL 擷取的數據的基本報告工作。
快樂的程序設計!
深入閱讀
如需本教學課程中所討論之主題的詳細資訊,請參閱下列資源:
- ASP.NET 主版頁面概觀
- ASP.NET 2.0 中的主版頁面
- ASP.NET 2.0 設計範本
- ASP.NET 網站導覽概觀
- 檢查 ASP.NET 2.0 的網站導覽
- ASP.NET 2.0 網站導覽功能
- 了解檢視狀態 ASP.NET
- 如何:啟用 ASP.NET 網頁的追蹤
- ASP.NET 使用者控制件
關於作者
Scott Mitchell 是 1998 年以來,1998 年與 Microsoft Web 技術合作的 七篇 ASP/ASP.NET 書籍和 4GuysFromRolla.com 作者。 Scott 是獨立的顧問、訓練者和作者。 他的最新書籍是 Sams 在 24 小時內自行 ASP.NET 2.0。 您可以透過mitchell@4GuysFromRolla.com部落格連到,也可以透過其部落格來存取,網址為 http://ScottOnWriting.NET。
特別感謝
本教學課程系列是由許多實用的檢閱者所檢閱。 本教學課程的首席檢閱者是 Liz Shulok、Dennis Patterson 和一個紀念者 Giesenow。 想要檢閱即將推出的 MSDN 文章嗎? 如果是,請將一行放在 mitchell@4GuysFromRolla.com。