YUI Library JavaScript DHTML





    
Handling Menu Click Events

/*margin and padding on body element
  can introduce errors in determining
  element position and are not recommended;
  we turn them off as a foundation for YUI
  CSS treatments. */
body {
  margin:0;
  padding:0;
}








    /*
        Set the "zoom" property to "normal" since it is set to "1" by the 
        ".example-container .bd" rule in yui.css and this causes a Menu
        instance's width to expand to 100% of the browser viewport.
    */
    
    div.yuimenu .bd {
    
        zoom: normal;
    
    }




Handling Menu Click Events



  


This example demonstrates how to register a "click" event handler for a 
MenuItem instance.



Note: By default clicking outside of a Menu instance will hide it.  
Additionally, MenuItem instances without a submenu or a URL to navigate to will 
hide their parent Menu instance when clicked.  Click the "Show Menu" button 
below to make the Menu instance visible if it is hidden.

      



    /*
         Initialize and render the Menu when the element it is to be 
         rendered into is ready to be scripted.
    */
    YAHOO.util.Event.onAvailable("rendertarget", function () {
        /*
            "click" event handler for the Menu instance - used to keep the Menu 
            instance visible when clicked, since by default a Menu instance 
            will hide when clicked.
        */
        function onMenuClick(p_sType, p_aArgs, p_oValue) {
            this.show();
        }
        /*
             "click" event handler for each MenuItem instance - used to log 
             info about the MenuItem that was clicked.
        */
        function onMenuItemClick(p_sType, p_aArgs, p_oValue) {
            YAHOO.log(("index: " + this.index + 
                       ", text: " + this.cfg.getProperty("text") + 
                       ", value: " + p_oValue), "info", "example9");
        
        }
        /*
      Instantiate a Menu:  The first argument passed to the constructor
      is the id for the Menu element to be created, the second is an 
      object literal of configuration properties.
        */
        var oMenu = new YAHOO.widget.Menu("mymenu", { fixedcenter: true });
        /*
            Add items to the Menu instance by passing an array of object literals 
            (each of which represents a set of YAHOO.widget.MenuItem 
            configuration properties) to the "addItems" method.
        */
        oMenu.addItems([
            //  Register a "click" event handler for the first item.
            { text: "Item One", onclick: { fn: onMenuItemClick } },
            /*
                 Register a "click" event handler for the second item, 
                 passing a string arguemnt ("foo") to the event handler.
            */
            { text: "Item Two", onclick: { fn: onMenuItemClick, obj: "foo" } },
            /*
                 Register a "click" event handler for the third item and
                 passing and array as an argument to the event handler.
            */
            { text: "Item Three", onclick: { fn: onMenuItemClick, obj: ["foo", "bar"] } }
        ]);
        oMenu.subscribe("click", onMenuClick);
        /*
            Since this Menu instance is built completely from script, call the 
            "render" method passing in the DOM element that it should be 
            appended to.
        */
        oMenu.render("rendertarget");
        YAHOO.util.Event.addListener("menutoggle", "click", oMenu.show, null, oMenu);
    
    });
    

Show Menu





   
  
yui_2.7.0b.zip( 4,431 k)