Yahoo! Developer Network Home - Help

YUI Library Examples: Button Control: Link Buttons

Button Control: Link Buttons

This example demonstrates different ways to create a Button that functions like an HTML <a/> element.

From Markup

Yahoo! Yahoo! Yahoo!

From JavaScript

Yahoo!Yahoo!Yahoo!

Creating Link Buttons

A Link Button can be instantiated three different ways:

Using an existing <a/> element

A Link Button can be created using an existing <a/> element as a source element, the attributes of which are captured and used for the creation of a new element that replaces the source element inline.

1<id="linkbutton1" href="http://www.yahoo.com">Yahoo!</a> 
view plain | print | ?

Pass the id of the source element as the first argument to the Button's constructor. Additional configuration attributes for a Button can be set at instantiation time by specifying them in an object literal that is passed as the second argument to the Button's constructor. Note: the value of configuration attributes passed to the Button constructor will trump those of the corresponding HTML attributes of the original source element.

1var oLinkButton1 = new YAHOO.widget.Button("linkbutton1"); 
view plain | print | ?

Using pre-defined Button Control HTML

A Link Button can also be instantiated using pre-defined Button Control HTML: An element with a class of "yui-button" and "yui-link-button" containing a element with a class of "first-child" containing an <a/> element:

1<span id="linkbutton2" class="yui-button yui-link-button"
2    <span class="first-child"
3        <href="http://www.yahoo.com">Yahoo!</a> 
4    </span> 
5</span> 
6<span id="linkbutton3" class="yui-button yui-link-button"
7    <em class="first-child"
8        <href="http://www.yahoo.com">Yahoo!</a> 
9    </em> 
10</span> 
view plain | print | ?

To instantiate a Link Button using the Button Control HTML, pass the id of the Button's root element (the element with the classes "yui-button" and "yui-link-button" applied) as the first argument to constructor and any additional configuration attributes as the second argument via an object literal.

1var oLinkButton2 = new YAHOO.widget.Button("linkbutton2"); 
2var oLinkButton3 = new YAHOO.widget.Button("linkbutton3");        
view plain | print | ?

Using no existing HTML

To build a Link Button without any existing HTML, pass a set of configuration attributes as a single argument to the constructor using an object literal.

1var oLinkButton4 = new YAHOO.widget.Button({  
2                            type: "link",  
3                            id: "linkbutton4",  
4                            label: "Yahoo!",  
5                            href: "http://www.yahoo.com",  
6                            container: "linkbuttonsfromjavascript" }); 
view plain | print | ?

In most cases, it is necessary to specify the button's id, type, label and container (the HTML element that the button should be appended to once created). If an id is not specified for the button, one will be generated using the generateId method of the Dom utility. Similarly, if the "type" attribute is omitted, the default type of "button" will be applied.

Copyright © 2008 Yahoo! Inc. All rights reserved.

Privacy Policy - Terms of Service - Copyright Policy - Job Openings