XUL:menu
From MDC
« XUL Reference home [ Examples | Attributes | Properties | Methods | Related ]
An element, much like a button, that is placed on a menubar. When the user clicks the menu element, the child menupopup of the menu will be displayed. This element is also used to create submenus.
More information is available in the XUL tutorial.
- Attributes
- acceltext, accesskey, allowevents, command, crop, disabled, image, label, menuactive, open, sizetopopup, tabindex, value
- Properties
- accessibleType, accessKey, command, control, crop, disabled, image, itemCount, label, labelElement, menupopup, open, parentContainer, selected, tabIndex, value
- Methods
- appendItem, getIndexOfItem, getItemAtIndex, insertItemAt, removeItemAt
[edit] Example
<menubar id="sample-menubar">
<menu id="file-menu" label="File">
<menupopup id="file-popup">
<menuitem label="New"/>
<menuitem label="Open"/>
<menuitem label="Save"/>
<menuseparator/>
<menuitem label="Exit"/>
</menupopup>
</menu>
<menu id="edit-menu" label="Edit">
<menupopup id="edit-popup">
<menuitem label="Undo"/>
<menuitem label="Redo"/>
</menupopup>
</menu>
</menubar>
[edit] Attributes
|
Inherited from XUL element |
- acceltext
- Type: string
- Text that appears beside beside the menu label to indicate the shortcut key (accelerator key) to use to invoke the command. If this value is set, it overrides an assigned key set in the key attribute. This attribute does not apply to menus directly on the menubar.
- accesskey
- Type: character
- This should be set to a letter that is used as a shortcut key. This letter should be one of the characters that appears in the
labeltext for the element.
- allowevents
- Type: boolean
- If true, events are passed to children of the element. Otherwise, events are passed to the element only.
- crop
- Type: one of the values below
- If the label of the element is too big to fit in its given space, the text will be cropped on the side specified by the
cropattribute. An ellipsis will be used in place of the cropped text. If the box direction is reversed, the cropping is reversed.
-
start: The text will be cropped on its left side. -
end: The text will be cropped on its right side. -
left: Deprecated The text will be cropped on its left side. -
right: Deprecated The text will be cropped on its right side. -
center: The text will be cropped in the middle, showing both the start and end of the text normally. -
none: The text will be not be cropped using an ellipsis. However, the text will simply be cut off if it is too large. The side depends on the CSS text alignment.
- disabled
- Type: boolean
- Indicates whether the element is disabled or not. If this element is set to
truethe element is disabled. Disabled elements are usually drawn with grayed-out text. If the element is disabled, it does not respond to user actions, it cannot be focused, and thecommandevent will not fire.
- label
- Type: string
- The label that will appear on the element. If this is left out, no text appears.
- menuactive
- Type: boolean
- This attribute is set on an item in a menu when it is being hovered over. Typcially, the theme will use this to highlight the item. A
DOMMenuItemActiveevent will be sent to the item when the item is hovered over, and aDOMMenuItemInactiveevent will be sent to the item when the selection moves away.
- open
- Type: boolean
- For the
menutype buttons, theopenattribute is set totruewhen the menu is open. Theopenattribute is not present if the menu is closed.
- sizetopopup
- Type: one of the following values
- Indicates how the menu width and the menupopup width are determined. If the
sizetopopupattribute is left out or set tonone, the menu will be its preferred width and the popup may extend outside of this width, unaffected by the maximum width of the menu itself.
-
none: The width of the popup will not be constrained to the size of the menu. -
always: If set toalways, the menu's width will be the same as that necessary for the menupopup. If the menu has a maximum width, the popup will also be this width.
- value
- Type: string
- The string attribute allows you to associate a data value with an element. It is not used for any specific purpose, but you can access it with a script for your own use.
[edit] Properties
|
Inherited from XUL element Inherited from DOM element |
- accessibleType
- Type: integer
- A value indicating the type of accessibility object for the element.
- control
- Type: menu element
- Returns the enclosing menu that the item is inside, if any, or
nullif there is no enclosing menu.
- menupopup
- Type: menupopup element
- A reference to the menupopup used by the menu. This property is read-only.
- open New in Firefox 3
- Type: boolean
- This property will be set to true when the menu is open. The menu may be opened by setting the open property to true and closed by setting it to false.
- parentContainer New in Firefox 3
- Type: menu element
- Read only property that returns the containing menu element, or
nullif there isn't a containing menu.
[edit] Methods
|
Inherited from XUL element Inherited from DOM element |
- appendItem( label, value )
- Return type: element
- Creates a new item and adds it to the end of the existing list of items. You may optionally set a value. The function returns the newly created element.
- getIndexOfItem( item )
- Return type: integer
- Returns the zero-based position of the specified item. Items are numbered starting at the first item displayed in the list.
- getItemAtIndex( index )
- Return type: element
- Returns the element that is at the specified index.
- insertItemAt( index, label, value )
- Return type: element
- This method creates a new item and inserts it at the specified position. You may optionally set a value. The new item element is returned.
- removeItemAt( index )
- Return type: element
- Removes the child item in the element at the specified index. The method returns the removed item.
[edit] Related
- Elements
- menubar, menuitem, menulist, menupopup, menuseparator