动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > ASP.NET技巧
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ ASP.NET技巧 ]的信息

本月文章推荐
.在asp.net中实现删除DataGrid的某.
.简写的通用数据层代码.
.通过System.Web.Mail程序发邮件.
.ASP.NET2.0中用ICallbackEventHa.
.asp.net(vb.net)连接sql server .
.使用ASP.NET Atlas编写显示真实进.
.asp.net开发wap必备:更好的匹配.
.深度解析ASP.NET2.0中的Callback.
.使用HttpWebRequest向网站模拟上.
.存储过程的分析.
.TreeView使用笔记.
..NET精简框架的“无法找到资源程.
.ASP.NET图象处理详解(1).
.asp.net2.0 上传图片并为用户创建.
.在ASP.NET中上传图片并生成缩略图.
.ASP.NET 2.0 多文件上传小经验 .
.页面中包括DataGrid时,利用webc.
.如何在页面之间传递数据量较大的.
.ASP.NET 2.0防止同一用户同时登陆.
.asp.net 2.0中用GRIDVIEW插入新记.

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

发表日期:2004-10-9 |


  文/廖煜嵘

  几乎每个网站里,为了方便用户在网站中进行页面导航,都少不了使用页面导航控件。有了页面导航的功能,用户可以很方便地在一个复杂的网站中进行页面之间的跳转。在以往的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>

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



上一篇:结合JavaScript与ASP.NET Web窗体进行程序开发 人气:18666
下一篇:在ASP.NET中点击一个按钮后让它变灰的简单方法 人气:11561
浏览全部ASP.NET的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-9-5 Coppermine Photo Gallery v1.4.
2008-9-5 清松网络日记本 v2.4
2008-9-5 AyWeb企业网站管理系统 v2.3 bui
2008-9-5 美女写真小偷程序联盟 v3.0 buil
2008-9-5 老Y文章管理系统 v2.1
2008-9-5 SiteDynamic企业网站管理系统 v1
2008-9-5 MyCOM企业网站管理系统 v1.0 Bui
2008-9-5 乐风CMS影视版 2008
2008-9-5 幻影电影视频系统TvsCms v1.3 伪
2008-8-23 Mini WinMount V0.4
2008-8-23 Vista优化大师3.11正式版
2008-8-23 Wine 1.13
2008-8-23 KlipFolio 5.0 Build 5899-80
2008-8-23 Windows Sysinternals Desktops
2008-8-23 OneTap Movies1.2破解版
2008-8-23 AnnotaterPDF阅读1.1.503 破解版
2008-8-23 SoundMeter分贝测量仪 v1.0汉化破
2008-8-23 iDrum音乐节拍1.0破解版
  发表评论
姓 名: 验证码:
内 容:
站长工具:网站收录查询 | Google PR查询 | ALEXA排名查询 | CSS在线编辑器 | 广告代码 | Html转换js | js/vbs加密 | md5加密 | 进制转换
实用工具:汉字翻译拼音 | 符号对照表 | 个税计算 | 经典小工具 | 汉字简繁转换 | 普通单位换算 | 公制单位换算 | 生辰老黄历 | 国内电话区号 国家代码与域名缩写 | 文字加密解密 | 健康查询 | 万年历 | 汉字横竖排版 | 手机号码查询 | 计算器 | ip搜索
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号
ホームページ制作 不動産検索システム 求人情報
防水工事·改修工事 フットサル大会 探偵