[<asp:HyperLink ID="lnkPrev" runat="server">Prev</asp:HyperLink>] | [<asp:HyperLink ID="lnkUp" runat="server">Up</asp:HyperLink>] | [<asp:HyperLink ID="lnkNext" runat="server">Next</asp:HyperLink>] |
If SiteMap.CurrentNode IsNot Nothing Then '设置next/previous/up链接 If SiteMap.CurrentNode.PreviousSibling IsNot Nothing Then lnkPrev.NavigateUrl = SiteMap.CurrentNode.PreviousSibling.Url lnkPrev.Text = "< Prev (" & SiteMap.CurrentNode.PreviousSibling.Title & ")" Else lnkPrev.NavigateUrl = String.Empty lnkPrev.Text = "< Prev" End If If SiteMap.CurrentNode.ParentNode IsNot Nothing Then lnkUp.NavigateUrl = SiteMap.CurrentNode.ParentNode.Url lnkUp.Text = "Up (" & SiteMap.CurrentNode.ParentNode.Title & ")" Else lnkUp.NavigateUrl = String.Empty lnkUp.Text = "Up" End If If SiteMap.CurrentNode.NextSibling IsNot Nothing Then lnkNext.NavigateUrl = SiteMap.CurrentNode.NextSibling.Url lnkNext.Text = "(" & SiteMap.CurrentNode.NextSibling.Title & ") Next >" Else lnkNext.NavigateUrl = String.Empty lnkNext.Text = "Next >" End If End If |
这将把三个超级链接Next,Up和Previous添加到从主页面继承的每一个页面,参见下图的快照。
四、 用SiteMapPath控件显示Breadcrumbs
SiteMapPath控件显示一个breadcrumb-它用于向用户显示他们在该站点结构中所处的位置。SiteMapPath控件的输出由下列三个因素决定:
·站点的结构,由站点地图定义,
·被访问的页面和
·SiteMapPath控件的属性值
当访问一个有SiteMapPath控件的页面时,该SiteMapPath控件试图把页面的URL映射到定义在该站点地图中的一个站点地图结点的url值。如果找到一个匹配,该控件将上行遍历该结构到根部,并作下列输出:RootNode>ParentNode>...>ParentNode>CurrentNode。这里的CurrentNode是站点地图结点的标题-它用来映射当前页面请求的URL;RootNode和ParentNodes被作为超级链接生成,如果该站点地图结点有一个定义在该站点地图中的URL值。在"History Books"页面(Books/History.aspx)中的一个SiteMapPath控件将生成Home>Books>History,同时还分别生成超级链接形式的Home和Books,分别回指向Default.aspx和Books/Default.aspx。在访问Books/Default.aspx时,SiteMapPath生成Home>Books。
非常清楚,SiteMapPath的输出既依赖于站点地图本身又依赖于正在被访问的页面。该SiteMapPath的输出可以被定制,通过该控件的属性。有一些标准Web控件格式的属性-BackColor,Font,ForeColor,等等-还有一些特定于SiteMapPath的设置,包括:
u PathDirection-可以取两个值之一它们是RootToCurrent(缺省的)或CurrentToRoot。当取值为RootToCurrent,在"History Books"页面上的breadcrumb生成为Home>Books>History;当取值为CurrentToRoot,输出将是History>Books>Home。
·PathSeparator-指定用于分开breadcrumb中的每个结点的字符串;缺省为>
·RenderCurrentNodeAsLink-一个Boolean属性-它指定是否CurrentNode应该生成为一个链接;缺省为False。
·ParentLevelsDisplayed-一个整数值-它可以用于限制breadcrumb所显示树层结构的高度。缺省地,这个属性值是-1,这意味着没有限制;把它的值置为1,那么在"History Books"页面将生成breadcrumb Books>History。根不包含在内,因为SiteMapPath控件只是向上遍历到一个父级-从"History"到"Book"。
·ShowToolTips-如果一站点地图结点有一个描述值,那么该描述对于每一个breadcrumb结点被显示为一个提示文本,如果这个属性被设置为True(默认情况)。
还有风格属性可用来设置BackColor,Font,ForeColor,等等-用于SiteMapPath控件的各个部分。可以使用NodeStyle属性来定制在breadcrumb中的结点的外观;可以使用RootNodeStyle和CurrentNodeStyle来进一步定制在breadcrumb中的第一个和最后一个结点。一般地,最简单也是最具有审美特点的来格式化该SiteMapPath控件的方法是使用它的"Auto Format"向导-这可以通过该控件的灵敏标签启动。
五、 用模板定制生成的输出
该SiteMapPath包含四个模板-它们允许进一步定制生成的输出。模板允许混合使用静态HTML标记,Web控件和数据绑定语法;如果你以前已使用了DataList或Repeater控件,那么你已对模板很熟悉了。在ASP.NET 2.0中的模板基本上同ASP.NET 1.x中的一样,除了ASP.NET 2.0引入了一些新的更精练的语法来数据绑定表达式外。例如,在ASP.NET 1.x中,你必须使用语法<%# DataBinder.Eval(Container.DataItem, PropertyName) %>来取得一列的值。而在ASP.NET 2.0中,这种老式的语法仍可以使用,但是你可以选择性地使用更短的版本<%# Eval(PropertyName) %>。
默认地,SiteMapPath以常规超级链接方式生成根和父结点,这样当用户点击该链接时,他们可以在该控件层次树上快速地向上回退。然而,在把信息发送回用户前,你可能想做一些服务器端处理-也许你想要记录下用户要到哪里去或自动地保存他们在该页面所做的任何变化。可以通过使用一个模板和把该结点生成为一个LinkButton来实现这一功能。
例如,如果你只想要把SiteMapPath的根结点生成为一个LinkButton,你可以用下面的标记来把一个<RootNodeTemplate>添加到SiteMapPath控件上:
<asp:SiteMapPath ID="SiteMapPath1" runat="server"> <RootNodeTemplate> <asp:LinkButton ID="LinkButton1" runat="server" Text='<%# Eval("title") %>' CommandArgument='<%# Eval("url") %>' OnCommand="LinkButton1_Command"> </asp:LinkButton> </RootNodeTemplate> </asp:SiteMapPath> |
ASP编码教程:如何实现/使用缓存
[ASP]2015年4月15日ASP编码教程:asp缓存的分类
[ASP]2015年4月15日ASP编码教程:何谓ASP缓存/为什么要缓存
[ASP]2015年4月15日ASP编码教程:asp实现的sha1加密解密代码
[ASP]2015年4月15日ASP编码教程:asp执行带参数的sql语句实例
[ASP]2015年4月14日