MenuItem Edit

MenuItem is a component which renders a button intended to be used in combination with the DropdownMenu component.

Usage Usage

import { MenuItem } from '@wordpress/components';
import { useState } from '@wordpress/element';

const MyMenuItem = () => {
    const [ isActive, setIsActive ] = useState( true );

    return (
        <MenuItem
            icon={ isActive ? 'yes' : 'no' }
            isSelected={ isActive }
            onClick={ () => setIsActive( ( state ) => ! state ) }
        >
            Toggle
        </MenuItem>
    );
};

Top ↑

Props Props

MenuItem supports the following props. Any additional props are passed through to the underlying Button.

Top ↑

children children

  • Type: WPElement
  • Required: No

Element to render as child of button.

Top ↑

info info

  • Type: string
  • Required: No

Text to use as description for button text.

Refer to documentation for label.

Top ↑

icon icon

  • Type: string
  • Required: No

Refer to documentation for Button’s icon prop.

Top ↑

iconPosition iconPosition

  • Type: string
  • Required: No
  • Default: 'right'

Determines where to display the provided icon.

Top ↑

isSelected isSelected

  • Type: boolean
  • Required: No

Whether or not the menu item is currently selected.

Top ↑

shortcut shortcut

  • Type: string or object
  • Required: No

If shortcut is a string, it is expecting the display text. If shortcut is an object, it will accept the properties of display (string) and ariaLabel (string).

Top ↑

role role

  • Type: string
  • Require: No
  • Default: 'menuitem'

Aria Spec. If you need to have selectable menu items use menuitemradio for single select, and menuitemcheckbox for multiselect.