• 使用递归从数据库读取数据来动态建立菜单


    表结构与内容

    MenBh            MenText     Bhparent

    0001             文件         

    0002             编辑         

    0005             打开          0001

    0006             新建          0001

    0011             access数据库  0006

    0012             VFPDbf      0006

    0013             剪切          0002

    0014             复制          0002

    0015            完全复制       0014

        

    Private m As New MainMenu()

        Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load

            Dim conn As New SqlConnection("server=localhost;uid=sa;pwd=;database=jiang")

            Dim cmd As New SqlCommand("select * from a_menu ", conn)

            Dim ds As New DataSet()

            Dim sqldpr As New SqlDataAdapter(cmd)

            sqldpr.Fill(ds, "menu")

            Me.DataGrid1.DataSource = ds.Tables("menu")

            '创建关系

            Dim dr As New DataRelation("self_menu", ds.Tables("menu").Columns("MenBh"), ds.Tables("menu").Columns("Bhparent"))

            ds.Relations.Add(dr)

            Dim r1 As DataRow

            '查找最高的菜单级别,也就是Bhparent列为空的行

            For Each r1 In ds.Tables("menu").Rows

                If r1.IsNull("Bhparent") Then

                    addmenuitem(r1, Nothing)

                End If

            Next

            Me.Menu = m '指定主窗体菜单

        End Sub

        '递归函数

        Private Sub addmenuitem(ByVal r As DataRow, ByVal item As MenuItem)

            Dim mi As MenuItem

            '如果是最外层菜单,要直接添加

            If item Is Nothing Then

                mi = m.MenuItems.Add(r.Item("MenText"))

            Else '如果是下级菜单要在菜单项的上级添加

                mi = item.MenuItems.Add(r.Item("MenText"))

            End If

            Dim r2 As DataRow

            For Each r2 In r.GetChildRows("self_menu")

                addmenuitem(r2, mi)

            Next

        End Sub

    '--------------------------------------------------------一种方法的改进

    /////////////////////////////////////////////////////////////////////////////////////

    继承自menuitem的类

    /////////////////////////////////////////////////////////////////////////////////////

    Public Class mymenuitem

    Inherits System.Windows.Forms.MenuItem

     

    Public Sub New(ByVal s As String, ByVal tag As String)

            MyBase.New()

            Me.Text = s

            m_tag = tag

        End Sub

        Private m_tag As String

        Public Property tag() As String

            Get

                Return m_tag

            End Get

            Set(ByVal Value As String)

                m_tag = Value

            End Set

    End Property

      End class



    ////////////////////////////////////////////////////////////////////////////////////

    在代码中实现这种菜单项的添加和菜单的建立

    //////////////////////////////////////////////////////////////////////////////////

    Private m As New MainMenu()

        Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load

            Dim conn As New SqlConnection("server=localhost;uid=sa;pwd=;database=jiang")

            Dim cmd As New SqlCommand("select * from a_menu ", conn)

            Dim ds As New DataSet()

            Dim sqldpr As New SqlDataAdapter(cmd)

            sqldpr.Fill(ds, "menu")

     

     

            'Me.DataGrid1.DataSource = ds.Tables("menu")

            Me.DataGrid1.DataSource = ds

            Me.DataGrid1.DataMember = "menu"

            '创建关系

            Dim dr As New DataRelation("self_menu", ds.Tables("menu").Columns("MenBh"), ds.Tables("menu").Columns("Bhparent"))

            ds.Relations.Add(dr)

            Dim r1 As DataRow

     

            '查找最高的菜单级别,也就是Bhparent列为空的行

            For Each r1 In ds.Tables("menu").Rows

                If r1.IsNull("Bhparent") Then

                    addmenuitem(r1, Nothing)

                End If

            Next

            Me.Menu = m '指定主窗体菜单

        End Sub

        '递归函数

        Private Sub addmenuitem(ByVal r As DataRow, ByVal item As MenuItem)

            Dim mi As MenuItem

     

            '如果是最外层菜单,要直接添加

            If item Is Nothing Then

                Try

                    mi = New mymenuitem(r.Item("MenText"), "1")

                    m.MenuItems.Add(mi)

                Catch ex As Exception

                    MessageBox.Show(ex.ToString)

                End Try

            Else '如果是下级菜单要在菜单项的上级添加

                mi = New mymenuitem(r.Item("MenText"), "2")

                item.MenuItems.Add(mi)

            End If

            Dim r2 As DataRow

            For Each r2 In r.GetChildRows("self_menu")

                addmenuitem(r2, mi)

            Next

        End Sub

  • 相关阅读:
    (一)MySQL中的常见查询
    PCI设备内存操作函数总结 分类: 浅谈PCI 2014-05-26 17:48 580人阅读 评论(0) 收藏
    HI3531由DMA 发起PCIe 事务 分类: HI3531 浅谈PCI-E windows驱动程序WDM 2014-05-23 11:48 930人阅读 评论(0) 收藏
    hi3531的pcie atu资源重映射 分类: HI3531 浅谈PCI-E 2014-05-21 09:17 695人阅读 评论(0) 收藏
    如何访问pcie整个4k的配置空间 分类: 浅谈PCI-E 2014-05-17 15:13 858人阅读 评论(0) 收藏
    hi3531的pcie控制器使能 分类: HI3531 2014-05-15 18:01 698人阅读 评论(0) 收藏
    hi3531 SDK 编译 kernel, 修改 参数 分类: arm-linux-Ubuntu HI3531 2014-05-07 11:23 1120人阅读 评论(0) 收藏
    如何实现Linux下的U盘(USB Mass Storage)驱动 分类: arm-linux-Ubuntu 2014-05-04 18:03 565人阅读 评论(0) 收藏
    从VGA到GPU!细数二十年显卡发展历程 分类: 生活百科 2014-04-29 17:29 448人阅读 评论(0) 收藏
    VxWorks中的中断应用设计要点 分类: vxWorks 2014-04-29 17:25 494人阅读 评论(0) 收藏
  • 原文地址:https://www.cnblogs.com/zhangchenliang/p/791678.html
Copyright © 2020-2023  润新知