原文:http://blog.csdn.net/pan_junbiao/article/details/8579293

ASP.NET的面包屑导航控件、树形导航控件、菜单控件。

1、 面包屑导航控件——SiteMapPath控件

SiteMapPath控件可以为站点提供“面包屑导航”的功能。

1.1 创建站点地图文件Web.sitemap

在ASP.Net中,有一个叫站点地图的XML文件。站点地图的文件名必须是Web.sitemap,而且需要放置于应用程序的根目录。

  1. <?xml version="1.0" encoding="utf-8" ?>
  2. <siteMap xmlns="http://schemas.microsoft.com/AspNet/SiteMap-File-1.0">
  3. <siteMapNode url="" title="人力资源管理" description="">
  4. <siteMapNode url="" title="员工管理" description="">
  5. <siteMapNode url="/Manager/UserList.aspx" title="员工列表" description="" />
  6. <siteMapNode url="/Manager/AddUser.aspx" title="新增员工" description="" />
  7. </siteMapNode>
  8. <siteMapNode url="" title="部门管理" description="">
  9. <siteMapNode url="/Manager/DepartmentList.aspx" title="部门列表" description="" />
  10. <siteMapNode url="/Manager/AddDepartment.aspx" title="新增部门" description="" />
  11. </siteMapNode>
  12. </siteMapNode>
  13. </siteMap>
<?xml version="1.0" encoding="utf-8" ?>
<siteMap xmlns="http://schemas.microsoft.com/AspNet/SiteMap-File-1.0">
<siteMapNode url="" title="人力资源管理" description="">
<siteMapNode url="" title="员工管理" description="">
<siteMapNode url="/Manager/UserList.aspx" title="员工列表" description="" />
<siteMapNode url="/Manager/AddUser.aspx" title="新增员工" description="" />
</siteMapNode>
<siteMapNode url="" title="部门管理" description="">
<siteMapNode url="/Manager/DepartmentList.aspx" title="部门列表" description="" />
<siteMapNode url="/Manager/AddDepartment.aspx" title="新增部门" description="" />
</siteMapNode>
</siteMapNode>
</siteMap>

节点描述如下:

siteMap:根节点,一个站点地图只能有一个siteMap元素。

siteMapNode:对应于页面的节点,一个节点描述一个页面。

title:描述页面。

url:文件在解决方案中的位置。

description:说明性文本。

编写站点地图的注意事项如下:

1、站点地图根节点为<siteMap>元素,每个文件有且仅有一个根节点。

2、<siteMap>下一级有且仅有一个<siteMapNode>节点。

3、<siteMapNode>下面包含多个新的<siteMapNode>节点。

4、在站点地图中,同一个URL仅能出现一次。

1.2 页面中编写SiteMapPath控件

  1. <asp:SiteMapPath ID="SiteMapPath1" runat="server">
  2. </asp:SiteMapPath>
<asp:SiteMapPath ID="SiteMapPath1" runat="server">
</asp:SiteMapPath>

SiteMapPath控件的常用属性

PathSeparator:控制分隔符。可以通过编辑模板更改分隔符为任意样式,比如为图片。

ParentLevelsDisplayed:要显示的父节点的级数,用于控制导航显示的级数。

2、 树形导航——TreeView控件

ASP.NET中有TreeView导航控件,可以像SiteMapPath那样设置一下XML文件即可显示强大的导航。

2.1 编写XML文件——ManagerMenu.xml

也可以采用站点地图Web.sitemap作为TreeView的数据源

  1. <?xml version="1.0" encoding="utf-8" ?>
  2. <siteMapNode url="" title="人力资源管理" description="">
  3. <siteMapNode url="" title="员工管理" description="">
  4. <siteMapNode url="/Manager/UserList.aspx" title="员工列表" description="" />
  5. <siteMapNode url="/Manager/AddUser.aspx" title="新增员工" description="" />
  6. </siteMapNode>
  7. <siteMapNode url="" title="部门管理" description="">
  8. <siteMapNode url="/Manager/DepartmentList.aspx" title="部门列表" description="" />
  9. <siteMapNode url="/Manager/AddDepartment.aspx" title="新增部门" description="" />
  10. </siteMapNode>
  11. </siteMapNode>
<?xml version="1.0" encoding="utf-8" ?>
<siteMapNode url="" title="人力资源管理" description="">
<siteMapNode url="" title="员工管理" description="">
<siteMapNode url="/Manager/UserList.aspx" title="员工列表" description="" />
<siteMapNode url="/Manager/AddUser.aspx" title="新增员工" description="" />
</siteMapNode>
<siteMapNode url="" title="部门管理" description="">
<siteMapNode url="/Manager/DepartmentList.aspx" title="部门列表" description="" />
<siteMapNode url="/Manager/AddDepartment.aspx" title="新增部门" description="" />
</siteMapNode>
</siteMapNode>

2.2 页面中编写TreeView控件与绑定数据源

  1. <asp:TreeView ID="TreeView1" runat="server" DataSourceID="XmlDataSource1" ShowLines="True">
  2. <DataBindings>
  3. <asp:TreeNodeBinding DataMember="siteMapNode" NavigateUrlField="url" TextField="title" />
  4. </DataBindings>
  5. </asp:TreeView>
  6. <asp:XmlDataSource ID="XmlDataSource1" runat="server" DataFile="~/Manager/ManagerMenu.xml"></asp:XmlDataSource>
<asp:TreeView ID="TreeView1" runat="server" DataSourceID="XmlDataSource1" ShowLines="True">
<DataBindings>
<asp:TreeNodeBinding DataMember="siteMapNode" NavigateUrlField="url" TextField="title" />
</DataBindings>
</asp:TreeView>
<asp:XmlDataSource ID="XmlDataSource1" runat="server" DataFile="~/Manager/ManagerMenu.xml"></asp:XmlDataSource>

TreeView数据绑定的常用属性

TextField:设置显示的文字所绑定的字段或元素。

NavigateUrlField:设置链接对应的字段或元素值。

3、 菜单控件——Menu控件

ASP.NET中Menu控件,它提供一种动态和静态结合的方式进行菜单的显示。

3.1 页面中编写Menu控件与绑定数据源。

  1. <asp:Menu ID="Menu1" runat="server" DataSourceID="XmlDataSource2" Orientation="Horizontal">
  2. <DataBindings>
  3. <asp:MenuItemBinding DataMember="siteMapNode" NavigateUrlField="url"
  4. TextField="title" />
  5. </DataBindings>
  6. </asp:Menu>
  7. <asp:XmlDataSource ID="XmlDataSource2" runat="server" DataFile="~/Manager/ManagerMenu.xml"></asp:XmlDataSource>
<asp:Menu ID="Menu1" runat="server" DataSourceID="XmlDataSource2" Orientation="Horizontal">
<DataBindings>
<asp:MenuItemBinding DataMember="siteMapNode" NavigateUrlField="url"
TextField="title" />
</DataBindings>
</asp:Menu>
<asp:XmlDataSource ID="XmlDataSource2" runat="server" DataFile="~/Manager/ManagerMenu.xml"></asp:XmlDataSource>

ASP.NET的面包屑导航控件、树形导航控件、菜单控件的更多相关文章

  1. ASP.NET MVC 在项目中使用面包屑导航

    给框架添加一个面包屑导航 1.创建一个类 using System; using System.Collections.Generic; using System.Linq; using System ...

  2. .net验证控件,导航控件

    一.客户端验证(用户体验,减少服务器端压力) 二.服务器端验证(防止恶意攻击,客户端js很容易被绕过) 验证控件:RequiredFieldValidator:字段必填:RangeValidator: ...

  3. amazeui学习笔记--css(常用组件2)--面包屑导航Breadcrumb

    amazeui学习笔记--css(常用组件2)--面包屑导航Breadcrumb 一.总结 1.am-breadcrumb:用am-breadcrumb来声明面包屑导航控件,.am-breadcrum ...

  4. 夺命雷公狗ThinkPHP项目之----企业网站25之网站前台面包屑导航URL的完善

    如果想取出面包屑导航的url那么就必须在model层里面进行多取一个了: <?php namespace Home\Model; use Think\Model; class CategoryM ...

  5. PHP.52-TP框架商城应用实例-前台4-商品详情页-面包屑导航、AJAX浏览历史

    面包屑导航  思路:根据商品的主分类向上取出所有上级分类即可 1.在分类模型中增加取出所有上级分类的方法 /********** [面包屑导航]取出一个分类所有上级分类 **********/ pub ...

  6. 【完全开源】百度地图Web service API C#.NET版,带地图显示控件、导航控件、POI查找控件

    目录 概述 功能 如何使用 参考帮助 概述 源代码主要包含三个项目,BMap.NET.BMap.NET.WindowsForm以及BMap.NET.WinformDemo. BMap.NET 对百度地 ...

  7. Bootstrap <基础十八>面包屑导航(Breadcrumbs)

    面包屑导航(Breadcrumbs)是一种基于网站层次信息的显示方式.以博客为例,面包屑导航可以显示发布日期.类别或标签.它们表示当前页面在导航层次结构内的位置. Bootstrap 中的面包屑导航( ...

  8. 菜单导航/URHere/面包屑,通过CSS中的content简洁表达代码

    比如我们要写一个菜单导航/URHere/面包屑,如: 首页 > 个人中心 > 修改密码 代码: <ul> <li><a href="javascri ...

  9. 缓存篇(Cache)~第一回 使用static静态成员实现服务器端缓存(导航面包屑)

    返回目录 今天写缓存篇的第一篇文章,在写完目录后,得到了一些朋友的关注,这给我之后的写作带来了无穷的力量,在这里,感谢那几位伙伴,哈哈! 书归正传,今天我带来一个Static静态成员的缓存,其实它也不 ...

随机推荐

  1. PHP+FLASH大文件断点续传功能分享

    1.使用PHP的创始人 Rasmus Lerdorf 写的APC扩展模块来实现(http://pecl.php.net/package/apc) APC实现方法: 安装APC,参照官方文档安装,可以使 ...

  2. UNIX环境--线程

    一.线程的概念 1.线程在进程中是负责执行代码的一个单位,可以说线程是进程的一部分.一个进程中至少要有一个主线程,进程可以拥有多个线程. 2.线程和进程一样,线程会共享进程的一些信息.比如,代码段.全 ...

  3. django操作cookie和session

    一.cookie:保存在客户端浏览器上的键值对 Cookie的由来 大家都知道HTTP协议是无状态的. 无状态的意思是每次请求都是独立的,它的执行情况和结果与前面的请求和之后的请求都无直接关系,它不会 ...

  4. vue 中 event.stopPropagation() 和event.preventDefault() 使用

    1.event.stopPropagation()方法 这是阻止事件的冒泡方法,不让事件向document上蔓延,但是默认事件任然会执行,当你掉用这个方法的时候,如果点击一个连接,这个连接仍然会被打开 ...

  5. java中的过滤器 --Filter

    package filter; import java.io.IOException; import javax.servlet.Filter; import javax.servlet.Filter ...

  6. 在linux下搭建go环境

    这几天小Jerry开始接触Go语言了,因为小Jerry学个东西必须要从最基础的开始弄懂,不然~她理解不了<hahaha> 所以,今天就来讲最基础,却也很容易让小Jerry这样的菜鸟感到困扰 ...

  7. Failed to find data source: kafka

    缺少包,在spark-submit 中指定 packages 如下: --packages org.apache.spark:spark-sql-kafka-0-10_2.11:2.1.0

  8. ps 和 pstree的用法

    ps 查看某个具体的命令进程: ps -C cmd-name: 如: ps -C httpd // 如果有多个名字相同的进程, 如httpd... 应该是它下面的子进程, 这时会显示第一个进程id. ...

  9. H5如何测试?

    它跟安卓APP与IOS APP有什么样的区别呢?★ 我们以往的APP是使用原生系统内核的,相当于直接在系统上操作,是我们传统意义上的软件,更加稳定 ★ H5的APP先得调用系统的浏览器内核,相当于是在 ...

  10. Could not load type 'System.Runtime.CompilerServices.ExtensionAttribute' from assembly 'mscorlib 的一种情形

    没有引用任何.net 4.5的东西,也没有引用 Newtonsoft.dll,原因是引用了微软的tlb类型库,引用方法如 https://www.cnblogs.com/nanfei/p/108798 ...