Click here to Skip to main content
Licence 
First Posted 8 May 2005
Views 236,604
Bookmarked 91 times

ASP.NET Dynamic XML Web Menu Control based on JavaScript

By | 22 Sep 2005 | Article
ASP.NET dynamic XML web menu control based on JavaScript.

Introduction

This is a free web based menu (JavaScript enabled) control. There are not many web menu controls available that support dynamic menu creation and binding. This WebMenu control supports dynamic menu creation, XML menu binding and also DataSet binding. This control uses triga (free script) JavaScript menu internally. Any complex menu structure can be represented using a simple XML schema. Menu position and style can be easily applied and changed dynamically without affecting the web application.

Steps to setup WebMenu

  1. Create a new ASP.NET web project, right click on ToolBox; choose 'Add/Remove items' and add the SuperControls.WebMenu.dll reference (compile SuperControls.WebMenu.cproj to get the DLL).
  2. Copy the JS files menu_tpl.js and menu.js to the root directory of the site.
  3. Copy menu stylesheet menu.css file to the subdirectory css.
  4. Copy menudata.xml to the root directory.
  5. Create an ASPX file and drag and drop the WebMenu control to the WebForm and use one of the methods (given below) to bind the XML/dynamic data to the menu control.

ASPX Code

<cc1:WebMenu id="WebMenu1" MenuXMLPath="\\ServerName\rad\menudata.xml" 
                                        PadWidth="24" runat="server">
</cc1:WebMenu>
<!--
Other samples
//**********************************************************************
<cc1:WebMenu id="WebMenu2" MenuXMLPath="ServerName\rad\menudata.xml" 
                      ImageArrow="<img src=images\\arrow.gif border=0" 
                      PadWidth="22" runat="server">
</cc1:WebMenu>
<cc1:WebMenu id="WebMenu3" MenuXMLPath="\\ServerName\rad\menudata.xml" 
                           ImageArrow="" PadWidth="26" runat="server">
</cc1:WebMenu>
-->

Ways of binding menu items dynamically...

Method 1

Set MenuXMLPath property with the path of the XML menu file in the server.

Method 2

Create new DataSet with the XML file and bind to the web menu control.

For example:

       DataSet dsMenu = new DataSet();
       dsMenu.ReadXml(@"\\ServerName\rad\menudata.xml");
       WebMenu1.DataSource = dsMenu;

Method 3

Get the menu data from database and populate the DataSet with the following structure:

  • Column 1 : menuid (unique ID of menu item).
  • Column 2 : name (name of the menu item).
  • Column 3 : root (parent of the menu item. If it is the starting/root item then the root value will be "" else it will be the value of the parent menuid).
  • Column 4 : url (URL for the menu item).

For example:

 WebMenu1.DataSource = dsMenu;
 // (Sample DataSet is given below.)

XML menu file (sample)

<?xml version="1.0" encoding="utf-8" ?> 
<menu>
    'Level 0 nodes
    <menuitem root="" name="Search Sites" menuid="1" />
    <menuitem root="" name="Webmail Sites"  menuid="2" />
    <menuitem root="" name="DotNet Sites"  menuid="3" />
    
    'Level 1 Items
    <menuitem root="1" name="Google" url="http://www.google.com" 
                                                        menuid="11"/>
    <menuitem root="1" name="Altavista" url="http://www.Altavista.com" 
                                                        menuid="12"/>
    
    'Level 1 Items
    <menuitem root="2" name="Hot-mail" url=""  menuid="21"/>
        'Level 2 Items
        <menuitem root="21" name="Hotmail" url="http://www.hotmail.com" 
                                                          menuid="211"/>
        <menuitem root="21" name="MSN" url="http://www.MSN.com" 
                                                          menuid="212"/>
        
    <menuitem root="2" name="Yahoo" url="http://www.yahoo.com" 
                                                           menuid="22"/>
    <menuitem root="2" name="Rediff" url="http://www.rediff.com" 
                                                           menuid="23"/>
    
    'Level 1 Items
    <menuitem root="3" name="Microsoft" url="http://www.Microsoft.com" 
                                                           menuid="31"/>
    <menuitem root="3" name="GotDotNet" url="http://www.GotDotNet.com" 
                                                           menuid="32"/>
    <menuitem root="3" name="CodeProject" url="http://www.CodeProject.com" 
                                                           menuid="33"/>
    <menuitem root="3" name="ASpdotnet" url="http://www.ASpdotnet.com" 
                                                           menuid="34"/>
    
</menu>

In the above sample, the root attribute represents the parent of the menu item. The root attribute will be empty for parent/level zero menu items.

Sample dynamic menu DataSet (with one DataTable)

root name menuid url
Search Sites 1
Webmail Sites 2
DotNet Sites 3
1 Google 11 http://www.google.com
1 Altavista 12 http://www.Altavista.com
2 Hot-mail 21
21 Hotmail 211 http://www.hotmail.com
21 MSN 212 http://www.MSN.com
2 Yahoo 22 http://www.yahoo.com
2 Rediff 23 http://www.rediff.com
3 Microsoft 31 http://www.Microsoft.com
3 GotDotNet 32 http://www.GotDotNet.com
3 CodeProject 33 http://www.CodeProject.com
3 ASpdotnet 34 http://www.ASpdotnet.com

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here

About the Author

Krishna_accent



United Arab Emirates United Arab Emirates

Member

Software Engineer from India,Working in .NET for 2 years.

Sign Up to vote   Poor Excellent
Add a reason or comment to your vote: x
Votes of 3 or less require a comment

Comments and Discussions

 
You must Sign In to use this message board. (secure sign-in)
 
Search this forum  
 FAQ
    Noise  Layout  Per page   
  Refresh
Questionmain root url Pinmemberegyptmaaaaan23:27 28 Jan '12  
GeneralMy vote of 3 Pinmemberbhargavpp23:28 15 Aug '11  
GeneralMenu is undefined PinmemberDeepak BOB19:39 12 Jul '10  
GeneralMasterPage Error Pinmemberwallaces52816:53 29 Nov '09  
GeneralI cant see the menu PinmemberKoval_Prad4:18 6 Oct '09  
Generalcant see anything Pinmembernandakumarse23:40 1 Jul '09  
Generalmenus position [modified] Pinmembersooberfellow21:15 30 Jun '09  
GeneralOracle connectivity Pinmemberkvalli22:32 15 Apr '09  
QuestionHow can i set the target frame.. Pinmemberryanjoseph14:53 8 Feb '09  
GeneralMicrosoft JScript runtime error: 'menu' is undefined PinmemberMember 161041520:14 23 Nov '08  
Generalunable to download the zipped file PinmemberMember 420613218:50 13 Aug '08  
Generalset menu as vertical and horiz Pinmemberramakrishna_yl21:25 18 Nov '07  
GeneralThank u a lot Pinmemberramakrishna_yl0:50 24 Oct '07  
AnswerRe: Thank u a lot PinmemberDeepak BOB19:37 12 Jul '10  
GeneralSystem.StackOverflowException Pinmemberramakrishna_yl23:50 23 Oct '07  
QuestionCan not see anything Pinmemberalexaz19:28 12 Oct '07  
Generalkewl Pinmemberchullan20:49 20 Jun '07  
GeneralPlease Inform me PinmemberPrapthi23:17 25 Mar '07  
GeneralGiving ERROR menu is undefined Pinmemberswapnali.mankar0:45 16 Mar '07  
hi ...
i am going to use this control first time ...
as the guidelines are provide ..i hav efaloowed all guidlines .
 
1)create new project .
2)i have copy the two menu js file in solution itself and same for menudata.xml.
3)i create one subdirectory name css in project and copy the menu css
4)included the dll.
5)populate dataset
6)bind dataset to webmenu.
now when i run the page i get the javascript error "menu is undefined"
 
did i copied the menu.js at right place ?
 
its in the root dir as you told ...
 
please rely soon....
 

 
gorakh borude.
GeneralRe: Giving ERROR menu is undefined PinmemberAndré FliP9:28 19 Apr '07  
GeneralRe: Giving ERROR menu is undefined Pinmembersolrac005:24 5 Feb '10  
GeneralTigra Menu Pinmembertreputt6:16 2 Mar '07  
Questionneed object in menu.js 78 [modified] Pinmemberhihba15:42 6 Feb '07  
Joketanx PinmemberJuan Carlos Guillén Zurita5:43 2 Feb '07  
GeneralI don't see anything either. PinmemberGrondal1:03 17 Nov '06  

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

Permalink | Advertise | Privacy | Mobile
Web02 | 2.5.120529.1 | Last Updated 22 Sep 2005
Article Copyright 2005 by Krishna_accent
Everything else Copyright © CodeProject, 1999-2012
Terms of Use
Layout: fixed | fluid