溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

ASP.NET 2.0中如何使用SiteMapDataSource控件

發(fā)布時(shí)間:2021-07-15 15:13:38 來(lái)源:億速云 閱讀:172 作者:Leah 欄目:編程語(yǔ)言

本篇文章給大家分享的是有關(guān)ASP.NET 2.0中如何使用SiteMapDataSource控件,小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。

數(shù)據(jù)源控件作為你的aspx頁(yè)面和底層數(shù)據(jù)的代理。為了顯示數(shù)據(jù)源控件查詢到的數(shù)據(jù),我們要添加其他Web控件到頁(yè)面上,并且將它和數(shù)據(jù)源控件綁定。要綁定一個(gè)Web控件到一個(gè)數(shù)據(jù)源控件,只需要簡(jiǎn)單的設(shè)置這個(gè)Web控件的DataSourceID屬性值為數(shù)據(jù)源控件的ID屬性值。

為了獲取站點(diǎn)地圖中的數(shù)據(jù),asp.net提供了SiteMapDataSource控件,它允許我們綁定一個(gè)Web控件來(lái)顯示我們的站點(diǎn)地圖。TreeView和Menu這兩個(gè)Web控件常常用來(lái)提供導(dǎo)航用戶界面。要綁定站點(diǎn)地圖中的數(shù)據(jù)到這兩個(gè)控件,添加一個(gè)SiteMapDataSource控件到頁(yè)面中,設(shè)置TreeView或者M(jìn)enu控件的DataSourceID屬性值為SiteMapDataSource控件的ID屬性值就可以了。舉個(gè)例子,我們可以用下面這些標(biāo)記將Menu控件到母板頁(yè)中:

< div id="navigation">      < asp:Menu ID="Menu1" runat="server"       DataSourceID="SiteMapDataSource1">      < /asp:Menu>       < asp:SiteMapDataSource ID="SiteMapDataSource1" runat="server" />  < /div>

為了生成優(yōu)化的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控件每次返回站點(diǎn)地圖層次中的一級(jí),從站點(diǎn)地圖中的根節(jié)點(diǎn)開始(在我們的站點(diǎn)地圖中是Home),然后是下一個(gè)級(jí)(Basic Reporting,Filtering Reports和Customized Formatting)等等。

當(dāng)將SiteMapDataSource綁定到Repeater時(shí),它遍歷***級(jí)并且用ItemTemplate顯示***級(jí)的每個(gè)SiteMapNode實(shí)例。我們可以使用Eval(屬性名稱)訪問(wèn)SiteMapNode的細(xì)節(jié),這樣我們就可以得到SiteMapNode的Url和Title屬性給HyperLink控件。

下面顯示的是上面使用Repeater控件例子生成的HTML標(biāo)記:

< 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>

從上面可以看出,站點(diǎn)地圖的第二級(jí)節(jié)點(diǎn)(Basic Reporting,Filtering Reports和Customized Formatting)被顯示而不是***個(gè)。

這是因?yàn)镾iteMapDataSource控件的ShowStartingNode屬性被設(shè)為false,導(dǎo)致SiteMapDataSource跳過(guò)了站點(diǎn)地圖的根節(jié)點(diǎn)取而代之的是從站點(diǎn)地圖的層次的第二級(jí)開始返回信息。

為了顯示Basic Reporting,Filtering Reports和Customized Formatting的子SiteMapNode,我們可以向先前的Repeater的ItemTemplate里添加另外一個(gè)Repeater。第二個(gè)Repeater將綁定到SiteMapNode實(shí)例的子結(jié)點(diǎn)屬性,如下:

< 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>

這兩個(gè)Repeater生成的HTML標(biāo)記(為了節(jié)省篇幅一些標(biāo)記被移除了):

< 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>

使用的CSS風(fēng)格選擇自Rachel Andrew的書:The CSS Anthology: 101 Essential Tips, Tricks, & Hacks,< ul>和< li>元素的風(fēng)格將顯示如下:

ASP.NET 2.0中如何使用SiteMapDataSource控件

圖11:用兩個(gè)Repeater和一些CSS顯示的菜單

這個(gè)菜單在母板頁(yè)中定義的,綁定了在Web.sitemap中定義的站點(diǎn)地圖,這意味著所有站點(diǎn)地圖的修改會(huì)立即反應(yīng)到所有使用了Site.master母板頁(yè)的頁(yè)面。

關(guān)掉視圖狀態(tài)

所有的asp.net控件可以隨意的保持它們的狀態(tài)到View State(譯注:當(dāng)原文中采用的是開頭字母大寫的ViewState將不翻譯)中,最終生成HTML時(shí)它被系列化并保存在一個(gè)隱藏的表單域中。控件用ViewState來(lái)記憶它們?cè)陧?yè)面返回時(shí)被程序改變的狀態(tài),比如Web控件綁定的數(shù)據(jù)。如果視圖狀態(tài)允許信息可以在頁(yè)面返回時(shí)保持,它會(huì)增大發(fā)送到客戶端HTML代碼的尺寸,如果在沒(méi)有確切的監(jiān)控下會(huì)使頁(yè)面膨脹得很厲害。數(shù)據(jù)顯示控件-尤其是GridView控件-會(huì)顯著地增加大量的額外的標(biāo)記到頁(yè)面中。當(dāng)然,這些增長(zhǎng)可能對(duì)寬帶用戶毫無(wú)影響,但是視圖狀態(tài)會(huì)給撥號(hào)上網(wǎng)的用戶增加幾秒鐘的延遲。

要觀察視圖狀態(tài)的影響,在瀏覽器里打開這個(gè)頁(yè)面然后查看頁(yè)面的源代碼(對(duì)于Internet Explorer,點(diǎn)擊”查看”菜單并且選擇源代碼選項(xiàng))。你還可以打開頁(yè)面跟蹤選項(xiàng)以觀察這個(gè)頁(yè)面上每個(gè)控件的視圖狀態(tài)。視圖狀態(tài)的信息被系列化并放在位于跟隨在< form>標(biāo)簽后面的< div>元素里的名為_VIEWSTATE的隱藏表單域中。

視圖狀態(tài)只在頁(yè)面上使用了Form時(shí)才會(huì)被保持;如果你的aspx頁(yè)面沒(méi)有包含

< form runat=”server”>的聲明,那么***產(chǎn)生的HTML標(biāo)記中將不含有VIEWSTATE隱藏表單域。

母板頁(yè)產(chǎn)生的VIEWSTATE隱藏表單域大概有1800個(gè)字節(jié)。這些額外的數(shù)據(jù)主要是SiteMapDataSource控件為Repeater控件提供的數(shù)據(jù)內(nèi)容產(chǎn)生的。也許1800字節(jié)左右看起來(lái)還不算很多,但是使用了GridView并且使用了很多字段和記錄的視圖狀態(tài)很容易就膨脹10倍或更多。

可以將EnableViewState屬性設(shè)為false在頁(yè)面級(jí)或者控件級(jí)關(guān)閉視圖狀態(tài),從而可以減少產(chǎn)生的標(biāo)記的大小。Web控件利用視圖狀態(tài)在頁(yè)面返回時(shí)保持要綁定到數(shù)據(jù)顯示控件的數(shù)據(jù),當(dāng)關(guān)閉了數(shù)據(jù)顯示控件的視圖狀態(tài)后,在每次頁(yè)面返回時(shí)都必須重新綁定數(shù)據(jù)到控件。在asp.net 1.x的時(shí)候這個(gè)職責(zé)落到開發(fā)者身上;在asp.net 2.0里,頁(yè)面返回時(shí),數(shù)據(jù)顯示控件會(huì)在必要的時(shí)候重新綁定數(shù)據(jù)。

設(shè)置Repeater控件的EnableViewState為false可以減少頁(yè)面的視圖狀態(tài)??梢酝ㄟ^(guò)屬性窗口設(shè)置或者在代碼視圖里手動(dòng)修改。通過(guò)這些改變,Repeater標(biāo)記將會(huì)像這樣:

< asp:Repeater runat="server" ID="menu" DataSourceID="SiteMapDataSource1"   EnableViewState="False">      < ItemTemplate>           < i>ItemTemplate contents omitted for brevity< /i>       < /ItemTemplate>  < /asp:Repeater>

經(jīng)過(guò)這些變化,頁(yè)面產(chǎn)生的視圖狀態(tài)減少到52個(gè)字節(jié),減少了97%的視圖狀態(tài)數(shù)據(jù)!在這個(gè)指南系列里我會(huì)關(guān)閉所有數(shù)據(jù)控件的視圖狀態(tài)以減少產(chǎn)生標(biāo)記的大小。在大多數(shù)例子里會(huì)在沒(méi)有提示的情況下將EnableViewState屬性設(shè)為false。

以上就是ASP.NET 2.0中如何使用SiteMapDataSource控件,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI