分享
 
 
 

在ASP.NET 2.0中使用页面导航控件

王朝asp·作者佚名  2006-11-24
窄屏简体版  字體: |||超大  

文/廖煜嵘

几乎每个网站里,为了方便用户在网站中进行页面导航,都少不了使用页面导航控件。有了页面导航的功能,用户可以很方便地在一个复杂的网站中进行页面之间的跳转。在以往的WEB编程中,要写一个好的页面导航功能,并不是那么容易的,也要使用一些技巧。而在asp.net 2.0中,为了方便进行页面导航,新增了一个叫做页面导航控件sitemapdatasource,其中还可以绑定到不同的其他页面控件,比如treeview,menu等,十分灵活,使到能很方便地实现页面导航的不同形式,而且还提供了运行时的编程接口,可以以编程的形式动态实现页面导航控件。本文将简单以几个例子来介绍一下在asp.net 2.0中如何实现页面导航。

页面导航的结构和sitemapdatasource控件

在asp.net 2.0中,要实现页面导航,应该先以xml的形式,提供出整个网站的页面结构层次。我们可以编写一个叫web.sitemap的XML文本文件,在该文件中定义出整个要导航页面的结构层次。举例如下:

<?xml version="1.0" encoding="utf-8" ?>

<siteMap>

<siteMapNode title="Default" description="Home" url="Default.aspx" >

<siteMapNode title="Members" description="Members" url="Members.aspx">

<siteMapNode title="My Account" description="My Account" url="MyAccount.aspx" />

<siteMapNode title="PRoducts" description="Products" url="Products.aspx" />

</siteMapNode>

<siteMapNode title="Administration" description="Administration" url="~/Admin/Default.aspx">

<siteMapNode title="Customer" description="Customer Admin" url="~/Admin/Customer/default.aspx" />

<siteMapNode title="Products Admin" description="Products Admin" url="~/Admin/ProductsAdmin.aspx" />

</siteMapNode>

</siteMapNode>

</siteMap>

我们可以看到,其中,web.sitemap文件必须包含根结点sitemap。而且,设置一个父sitemapnode结点,该结点表明是默认的站点首页,在该父sitemapnode结点下,可以有若干个子sitemapnode结点,分别按层次结构代表了网站的各子栏目(留意一下上例中,各个子结点之间的包含关系)。而每一个sitemapnode结点中,有如下若干个属性:

1)URL属性:该属性指出要导航的栏目的地址链接,在web.sitemap中定义中,必须是每个栏目的相对地址。

2)Title属性:该属性指出每个子栏目的名称,显示在页面中。

3)Description属性:该属性指定时,则用户在鼠标移动到该栏目时,出现有关该栏目的相关提示,类似于tooltips属性。

在设计好sitemap属性后,接下来就可以一步步构建页面导航功能了,主要有两个步骤:

1) 向页面中添加sitemapdatasource控件。该控件会自动感应绑定web.sitemap中的内容。

2) 将sitemapdatasource控件绑定到如sitemappath,treeview,menu等控件中,也就是说,将它们的数据源设置为该sitemapdatasource控件。

知道了方法后,我们下面就分别以treeview,menu,sitemappath三种控件为例子,介绍一下如何和sitemapdatasource控件进行配合使用。

先来介绍使用treeview控件和sitemapdatasource 控件配合使用的方法。Treeview树形列表控件十分适合于用来做页面导航,为了能具体说明,我们充分利用asp.net中的masterpage控件,先搭建出一个网站的基本框架架构。

在visual web developer 2005 beta 1中,新建一个网站,之后添加上文的web.sitemap文件,再添加一个名叫Navigation的master类型的页面,代码如下:

<%@ Master Language="C#" %>

<html xmlns="www.w3.org/1999/xhtml" >

<head id="Head1" runat="server">

<title>Master Page</title>

</head>

<body>

<form id="form1" runat="server">

<div>

<table style="width: 100%; height: 100%" border="1">

<tr>

<td style="width: 10%">

<asp:TreeView ID="TreeView1" Runat="server" DataSourceID="SiteMapDataSource1"

ExpandDepth="2" ShowExpandCollapse="False" NodeIndent="10">

<LevelStyles>

<asp:TreeNodeStyle Font-Bold="True" Font-Underline="False"/>

<asp:TreeNodeStyle Font-Italic="True" Font-Underline="False" />

<asp:TreeNodeStyle Font-Size="X-Small" ImageUrl="bullet.gif" Font-Underline="False" />

</LevelStyles>

<NodeStyle ChildNodesPadding="10" />

</asp:TreeView>

</td>

<td style="width: 100px">

<asp:contentplaceholder id="ContentPlaceHolder1"runat="server">

</asp:contentplaceholder>

</td>

</tr>

</table>

<asp:SiteMapDataSource ID="SiteMapDataSource1" Runat="server"/>

</div>

</form>

</body>

</html>

在上面的代码中,其中的TREEVIEW控件中的DATASORUCE属性中,就指定了sitemapdatasource控件,并且在treeview控件中,也定义了不同结点的样式。

在完成了masterpage页面后,就等于已经把网站的模版页建立起来了,接下来就可以新建其他子页面,以继承masterpage页面,并且新建各自页面的内容了。比如,新建一个default.aspx页面,代码如下:

<%@ Page Language="C#" MasterPageFile="Navigation.master" Title="Default Page"%>

<asp:Content ContentPlaceHolderID="ContentPlaceHolder1"

ID="Content1" Runat="Server">

This is the default page

</asp:Content>

可以看到,当建立了模版页后,就可以新建其他的子页面了,只需要在其中的contentplaceholderid中写入不同的内容就可以了。运行起来后,效果如图:

接下来,我们来介绍如何将menu菜单控件和sitemapdatasource 控件配合使用。其中,我们在上面的例子的基础上,在<table style="width: 100%; height: 100%" border="1">下面增加如下代码就可以了,

<tr height="100px">

<td colspan="2" align="left">

<asp:Menu ID="Menu1" Runat="Server"

DataSourceID="SiteMapDataSource1">

</asp:Menu>

</td>

</tr>

其中,我们增加了一个menu控件,其中将其datasourceid属性设定为sitemapdatasource1就可以了,运行如下图,当然,我们可以改变menu控件的显示位置,如可以将其改成垂直样式显示。

而对于我们经常见到的显示出页面当前路径的导航条功能,在asp.net 2.0中也可以轻易实现,我们可以使用其中的sitemappath控件。我们紧接着在上文代码中的menu控件下,增加如下代码:

<tr height="100px">

<td colspan="2" align="left">

Currently Selected Page is:

<asp:SiteMapPath Runat="Server" ID="SiteMapPath1"></asp:SiteMapPath>

</td>

</tr>

要注意的是,只要增加sitemappath控件就可以了,因为它会自动和已经增加的sitemapdatasource控件进行绑定的。我们为了说明问题,另外增加一个页面member.aspx,代码如下:

<%@ Page Language="C#" MasterPageFile="Navigation.master" Title="Members Page"%>

<asp:Content ContentPlaceHolderID="ContentPlaceHolder1" ID="Content1" Runat="Server">

This is the members page

</asp:Content>

运行结果如下:

最后,我们看一下,如何通过编程的方式来获取页面导航中的相关数据。其中,必须引用到的是sitemap类,该类提供了很多相关的方法和属性,最重要的是currentnode属性,它可以指出当前用户正在浏览的是哪一个栏目页面,这用来跟踪用户在网站中的行动轨迹,并进行站点数据统计,有时是很有用的,举例如下:

<%@ Page Language="C#" MasterPageFile="Navigation.master" Title="Members Page"%>

<script runat="Server">

void Page_Load(object sender, EventArgs e)

{

Response.Write("The currently selected root node is: " + SiteMap.CurrentNode.Description + "<br>");

Response.Write("The Parent for the currently selected node is : " +

SiteMap.CurrentNode.ParentNode.Description);

}

</script>

<asp:Content ContentPlaceHolderID="ContentPlaceHolder1" ID="Content1" Runat="Server">

This is the members page

</asp:Content>

在这个例子中,使用程序的方式,得出了用户当前正在浏览的栏目页面,以及该栏目的父栏目的名称,运行结果如下图:

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有