vs2005 menu 無限循環 自動綁定下拉菜單內容

 前年寫了一遍 Vs 2005 treeview無限循環的文章http://blog.csdn.net/SpriteNet/archive/2008/04/02/2245363.aspx,最後提到說稍微修改可以用到 menu 控件上,最近項目用到了menu的綁定數據庫,思路和treeview一樣,也是遞歸的辦法,具體如何實現,咱們下次再說,先吃飯,佔個地方。。。。。。。(*^__^*) 嘻嘻……

 

 

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

 

回來了,咱們繼續

 

先說表結構吧,表結構其實和《Vs 2005 treeview無限循環》的結構是一樣的,不過就是多了一個記錄url的字段,大家可以看看《Vs 2005 treeview無限循環》的內容。

 

以下是相關代碼:

1.皮膚樣式

<%--Menu--%>
<asp:Menu runat="server" SkinID="MgeShow"
MaximumDynamicDisplayLevels="3"    Orientation="Horizontal" StaticDisplayLevels="2"
 BackColor="#396395" Font-Overline="False" ForeColor="#E0E0E0" Font-Size="30pt"  StaticSubMenuIndent="" StaticEnableDefaultPopOutImage="False" Font-Bold="True">
   <StaticMenuItemStyle HorizontalPadding="5px" VerticalPadding="4px"/>
   <DynamicHoverStyle BackColor="#7AB0EF" ForeColor="#ffffff" />
   <DynamicMenuStyle BackColor="#4982C5" BorderColor="#396395" BorderStyle="Outset" BorderWidth="1px" ForeColor="#FF7E00"/><%--Height="30px" HorizontalPadding="10px"--%>
   <StaticSelectedStyle BackColor="#396395" ForeColor="#E0E0E0" /> <%--無二級菜單時的一級樣式--%>
   <DynamicMenuItemStyle HorizontalPadding="5px" VerticalPadding="4px" Font-Strikeout="False" Height="24px" />
   <StaticHoverStyle BackColor="#4982C5" ForeColor="#ffffff" /> <%--導航第一級鼠標放上背景顏色和字體顏色--%> 
</asp:Menu>

 

 

2.cs

 

    protected void initMenu()
    {
        DataTable dt = GetViewTable();
        DataView dv = new DataView(dt);
        dv.RowFilter = "QB_Fid='0'";
 
        foreach (DataRowView drv in dv)
        {
            MenuItem node = new MenuItem();
            node.Text = drv["QB_Name"].ToString();
            node.Value = drv["QB_Id"].ToString();
            node.NavigateUrl = drv["QB_Url"].ToString().Trim();
            Menu1.Items.Add(node);

            AddNodes(dt, node);

        }


    }

    protected DataTable GetViewTable()
    {
        string strConn = System.Configuration.ConfigurationManager.AppSettings["strconnC"];
        SqlConnection myConn = new SqlConnection(strConn);
        string strSql = "select * from QX_Base where QB_JY=0 order by QB_Fid,QB_Sort";
        SqlDataAdapter myDa = new SqlDataAdapter(strSql, myConn);
        DataTable dt = new DataTable();
        myDa.Fill(dt);

            return dt;


    }

    /// <summary>
    /// 子節點添加
    /// </summary>
    /// <param name="dt">數據表</param>
    /// <param name="pNode"></param>
    protected void AddNodes(DataTable dt, MenuItem pNode)
    {
        DataView dv = new DataView(dt);

        dv.RowFilter = "QB_Fid =" + pNode.Value ;
        foreach (DataRowView drv in dv)
        {
            MenuItem menuNode = new MenuItem();

            menuNode.Text = drv["QB_Name"].ToString();
            menuNode.NavigateUrl = drv["QB_Url"].ToString().Trim();
            menuNode.Value = drv["QB_Id"].ToString();
            pNode.ChildItems.Add(menuNode);

            //loop循環
            AddNodes(dt, menuNode);

        }

    }

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章