关于ASP.NET 中站点地图sitemap 的使用
在ASP.NET MVC 如此火热的时期,我竟然不适时宜的谈起ASP.NET ,恐怕会引来一阵嘲笑。最为无趣的是,讲解的竟然还是其中的一个控件。oh~~ my god!my out! ^_^SiteMapPath 控件简介SiteMapPath 控件是一种站点导航控件,反映了SiteMap 对象提供的数据。它提供了一种定位站点的方式,动态显示当前页在站点中的相对位置,并提供了从当前页向上跳转的快捷方式。SiteMapPath 控件直接使用了站点地图(.sitemap)中配置的数据(无需通过SiteMapDataSource数据源控件)。示例一:SiteMapPath 控件的简单使用1、创建 Web.sitemap 文件在您的网站的根目录中创建一个名为 Web.sitemap 的文件。打开此 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="首页" description=""><siteMapNode url="Second.aspx" title="二页" description="" /><siteMapNode url="Third.aspx" title="三页" description="" /></siteMapNode></siteMap>注意:○ 如果在url 属性值中,列出了不存在的 URL 或列出了重复的 URL,将导致请求Web 应用程序将失败。○ 如果在url 属性值中,添加了相关参数(如:url="Second.aspx?id=1"),也有可能导致请求Web 应用程序将失败。○ 在url 属性值中,可以“~/”快捷键开头,该快捷键表示应用程序根目录。2、添加SiteMapPath 控件向网页Default.aspx 添加站点导航控件,其代码如下:<%@ Page Language="C#" %><!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 id="Head1" runat="server"><title>Simple Navigation Controls</title></head><body><form id="form1" runat="server"><h2>Using SiteMapPath</h2><asp:SiteMapPath ID="SiteMapPath1" Runat="server"></asp:SiteMapPath><!-- 此处的 SiteMapDataSource 控件是提供给TreeView 和 Menu 使用 --><asp:SiteMapDataSource ID="SiteMapDataSource1" Runat="server" /><h2>Using TreeView</h2><asp:TreeView ID="TreeView1" Runat="Server" DataSourceID="SiteMapDataSource1" /><h2>Using Menu</h2><asp:Menu ID="Menu2" Runat="server" DataSourceID="SiteMapDataSource1"/><h2>Using a Horizontal Menu</h2><asp:Menu ID="Menu1" Runat="server" DataSourceID="SiteMapDataSource1"Orientation="Horizontal" StaticDisplayLevels="2" /></form></body></html>注意:○ 只要在页面上拖放SiteMapPath 控件,页面就会自动显示站点地图。○ 此处代码顺便演示了SiteMapDataSource 控件如何提供给TreeView 和 Menu 使用。示例二:如何在根站点地图中添加子站点地图文件默认情况下,ASP.NET 站点导航使用一个名为 Web.sitemap 的 XML 文件,该文件描述网站的层次结构。但是,也有可能要使用多个站点地图文件或站点地图提供程序来描述整个网站的导航结构。1、若要为一个站点配置多个子站点地图,首先在根目录的站点地图中设置子站点地图的节点。在根站点地图Web.sitemap 中,将下面的 SiteMapNode 添加到文件的相应位置,代码如下:<siteMapNode siteMapFile="~/News/News.sitemap" />添加完以上节点后,根目录下的站点地图(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="首页" description=""><siteMapNode url="Second.aspx" title="二页" description="" /><siteMapNode url="Third.aspx" title="三页" description="" /><siteMapNode siteMapFile="~/News/News.sitemap" /></siteMapNode></siteMap>2、添加子站点,并创建相应的子目录的站点地图文件(News.sitemap),其代码如下:<?xml version="1.0" encoding="utf-8" ?><siteMap xmlns="http://schemas.microsoft.com/AspNet/SiteMap-File-1.0" ><siteMapNode url="~/News/NewsIndex.aspx" title="新闻首页" description=""><siteMapNode url="~/News/Sports.aspx" title="体育新闻" description="" /><siteMapNode url="~/News/Stars.aspx" title="明星新闻" description="" /></siteMapNode></siteMap>注意:子站点地图中,url 属性值一定要使用以“~/”快捷键开头的应用程序根目录路径,如:url="~/News/Stars.aspx"示例三:如何动态修改站点地图sitemap 中的属性值一个页面的内容要根据上一个页面所点击的链接来动态改变,这个倒是可以通过页面间的参数传递来实现。但是,如果站点地图(如:BBS.sitemap)中,相关节点 < siteMapNode > 的 title 属性值也要根据所点击的链接来动态改变,则需要通过一定的编码来实现。在此举例如下:一个论坛首页(https://www.xiaoyuani.com/)(BBSIndex.aspx)上有相关版块的超链接(如:Java 版块链接、C# 版块链接、SQL 版块链接),点击某一个版块链接后,跳转到论坛主题(Topic.aspx)页面。而该论坛主题(Topic.aspx)页面套用了一个模板页(TopicMaster.master),该模板页(TopicMaster.master)中添加了SiteMapPath 控件,该控件用来显示当前页面的版块名称,而该名称的字符值是从站点地图(BBS.sitemap)中相对应的节点(siteMapNode)取其 title 属性值。其站点结构如下图所示:
