TreeView用于实现树型菜单

转载 2006年06月06日 13:02:00

 

TreeView使用心得(一)
日期:2004年6月9日 星期三  位置:办公室  天气:晴朗  作者:china
在Asp.Net中,TreeView用于实现树型菜单最好的控件,实现方法如下:

具体方法是:创建一个数据库,设计树图信息表S_Menu,包含NodeId、ParentId、NodeName、Address、Icon字段,其它字段根据实际业务而定,节点名称NodeName将在树型控件的节点上显示,NodeId字段保存节点的唯一标识号,ParentId表示当前节点的父节点号,标识号组成了一个“链表”,记录了树上节点的结构。设计一个Web窗体其上放置TreeView控件,修改其属性Id为tvMenu。

数据结构如下:
CREATE TABLE [dbo].[S_Menu] (
 [NodeId] [char] (6) COLLATE Chinese_PRC_CI_AS NULL ,
 [ParentId] [char] (6) COLLATE Chinese_PRC_CI_AS NULL ,
 [NodeName] [nvarchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,
 [Address] [nvarchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,
 [Icon] [nvarchar] (50) COLLATE Chinese_PRC_CI_AS NULL
) ON [PRIMARY]
GO


数据库如下:
NodeId ParentId NodeName Address  Icon
100000 0  公共查询部   icon_document.gif
100001 100000  人民币日报查询 public/a1.aspx icon_settings.gif
100002 100000  外币日报查询 public/a2.aspx icon_settings.gif
100003 0  分行科技部   icon_document.gif
100004 100003  人民币日报查询 tech/a1.aspx icon_settings.gif
100005 100003  外币日报查询 tech/a2.aspx icon_settings.gif
100006 0  福田支行   icon_document.gif
100007 100006  月存款进度表 a1.aspx  icon_settings.gif
100008 100006  月存款走势图 a2.aspx  icon_settings.gif
100009 0  罗湖支行   icon_document.gif
100010 100009  月存款进度表 a1.aspx  icon_settings.gif
100011 100009  月存款走势图 a2.aspx  icon_settings.gif
    
menu_left.aspx文件如下:
<%@ Register TagPrefix="iewc" Namespace="Microsoft.Web.UI.WebControls" Assembly="Microsoft.Web.UI.WebControls, Version=1.0.2.226, Culture=neutral, PublicKeyToken=31bf3856ad364e35" %>
<%@ Page language="c#" Codebehind="menu_Left.aspx.cs" AutoEventWireup="false" Inherits="hzquery.menu.menu_Left" %>
<HTML>
 <HEAD>
  <title>menu_Left</title>
  <meta name="GENERATOR" Content="Microsoft Visual Studio 7.0">
  <meta name="CODE_LANGUAGE" Content="C#">
  <meta name="vs_defaultClientScript" content="JavaScript">
  <meta name="vs_targetSchema" content="http://schemas.microsoft.com/intellisense/ie5">
 </HEAD>
 <body MS_POSITIONING="GridLayout">
  <form id="menu_Left" method="post" runat="server">
   <iewc:TreeView id="tvMenu" runat="server"></iewc:TreeView>
  </form>
 </body>
</HTML>


CodeBehind代码如下:
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using Microsoft.Web.UI.WebControls;
using System.Data.SqlClient;


namespace hzquery.menu
{
 /// <summary>
 /// menu_Left 的摘要说明。
 /// </summary>
 public class menu_Left : System.Web.UI.Page
 {
  protected Microsoft.Web.UI.WebControls.TreeView tvMenu;
  SqlConnection Conn;
  SqlDataAdapter myCmd;
  DataSet ds;
  string cmdSelect;


  private void Page_Load(object sender, System.EventArgs e)
  {
   Conn=new SqlConnection(Application["ConnString"].To

TreeView使用心得(二)
日期:2004年6月9日 星期三  位置:办公室  天气:晴朗  作者:china

很多时候,我们需要实现在客户端显示和更新TreeView中的信息,通过Javascript控制是有效的手段之一,这时我们需要将TreeView放入FrameSet的中,如下:
<frameset cols="24%,76%">
  <FRAMESET rows="58%,42%">
   <frame name="left" src="treecview.aspx">
   <FRAME name="down" src="Summary.aspx">
  </FRAMESET>
  <FRAMESET rows="79%,21%" id="rightform">
   <frame name="right" src="Control.aspx">
   <FRAME name="rightdown">
  </FRAMESET>

然后,通过javascript:
parent.frames["right"].location.href="Control.aspx?id="+ xxx;
控制frameset中right内容的显示。

如果需要通过right刷新TreeView,则可以使用
parent.frames["left"].location.href="treecview.aspx"

TreeView使用心得(三)
日期:2004年6月9日 星期三  位置:办公室  天气:晴朗  作者:china

在Treeview中实现"全部展开"和"全部折叠"的功能,Expandnodes(Me.TreeView1, true)展开全部节点,Expandnodes(Me.TreeView1, false)折叠全部节点,如下:

public void Expandnodes(Microsoft.Web.UI.WebControls.TreeNode node,bool Expand)
{
    foreach(Microsoft.Web.UI.WebControls.TreeNode n in node.Nodes)
    {
 if(n.Nodes.Count>0)
 {
     n.Expanded = Expand;
     Expandnodes(n, Expand);
 }
     }
}
public void Expandnodes(Microsoft.Web.UI.WebControls.TreeView treeview, bool Expand)
{
 foreach(Microsoft.Web.UI.WebControls.TreeNode n in treeview.Nodes)
 {
                if(n.Nodes.Count>0)
        {
  n.Expanded = Expand;
  Expandnodes(n, Expand);
        }
 }
}

相关文章推荐

jQuery 树型菜单插件(Treeview)

jQuery 树型菜单插件(Treeview) jQuery Treeview 提供了一个无序灵活的可折叠的树形菜单。试用于一些菜单的导航,支持基于 cookie 的持久性菜单。 i...

用PHP实现多级树型菜单

//树型目录结构模板程序      //菜单目录库字段说明:      //menu_id 菜单项目 id      //menu 菜单名称      //menu_grade 菜单等级 1 为主菜单...

ASP.NET TreeView树型菜单操作实例

  • 2012年04月06日 16:55
  • 133KB
  • 下载

C# TreeView树型菜单控件

  • 2009年02月26日 14:56
  • 69KB
  • 下载

php实现无限级树型菜单(函数递归做法)

!!写递归函数,可考虑缓存,定义一些静态变量来存上一次运行的结果,多程序运行效率很有帮助. 大概步骤如下: 首先到数据库取数据,放到一个数组, 然后把数据转化为一个树型状的数组, 最后把这个树...

treeview静态树型JavaScript的实现

  • 2012年12月13日 13:26
  • 7KB
  • 下载

js 实现 树型目录菜单

  • 2010年03月30日 14:49
  • 3KB
  • 下载

用PHP实现windows资源管理器风格的树型菜单

以下是一个风格类似windows资源管理器的树型菜单 将下面的脚本包含到你的页面中 另外需要从资源管理器中截取一些gif图片,祥见脚本中的注释 菜单结构文件的格式为: tree lev...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:TreeView用于实现树型菜单
举报原因:
原因补充:

(最多只允许输入30个字)