--- title: DropdownMenu description: A menu to display actions when clicking on an element. links: - label: DropdownMenu icon: i-custom-radix-vue to: https://www.radix-vue.com/components/dropdown-menu.html - label: GitHub icon: i-simple-icons-github to: https://github.com/benjamincanac/ui3/tree/dev/src/runtime/components/Dropdown.vue --- ## Usage Use a [Button](/components/button) or any other component in the default slot of the DropdownMenu. ### Items Use the `items` prop as an array of objects with the following properties: - `label?: string`{lang="ts-type"} - `icon?: string`{lang="ts-type"} - `avatar?: AvatarProps`{lang="ts-type"} - `kbds?: string[] | KbdProps[]`{lang="ts-type"} - `type?: "link" | "label" | "separator"`{lang="ts-type"} - `disabled?: boolean`{lang="ts-type"} - `class?: any`{lang="ts-type"} - [`slot?: string`{lang="ts-type"}](#with-custom-slot) - `select?(e: Event): void`{lang="ts-type"} You can also pass any property from the [Link](/components/link#props) component such as `to`, `target`, etc. ::component-code --- prettier: true ignore: - items - class external: - items class: 'justify-center' props: items: - - label: Benjamin avatar: src: 'https://avatars.githubusercontent.com/u/739984?v=4' type: label - - label: Profile icon: i-heroicons-user - label: Billing icon: i-heroicons-credit-card - label: Settings icon: i-heroicons-cog kbds: - ',' - label: Keyboard shortcuts icon: i-heroicons-computer-desktop - - label: Team icon: i-heroicons-users - label: Invite users icon: i-heroicons-user-plus children: - - label: Email icon: i-heroicons-envelope - label: Message icon: i-heroicons-chat-bubble-left - - label: More icon: i-heroicons-plus-circle - label: New team icon: i-heroicons-plus kbds: - meta - n - - label: GitHub icon: i-simple-icons-github to: 'https://github.com/nuxt/ui' target: _blank - label: Support icon: i-heroicons-lifebuoy to: '/components/dropdown-menu' - label: API icon: i-heroicons-cloud disabled: true - - label: Logout icon: i-heroicons-arrow-right-on-rectangle kbds: - shift - meta - q class: 'w-48' slots: default: | --- :u-button{icon="i-heroicons-bars-3" color="gray" variant="outline"} :: ::tip Each item can take a `children` array to create a nested menu which can be controlled using the `open`, `defaultOpen` and `content` properties. :: ### Content Use the `content` prop to control how the DropdownMenu content is rendered, like its `align` or `side` for example. ::component-code --- prettier: true ignore: - items - class external: - items items: content.align: - start - center - end content.side: - right - left - top - bottom class: 'justify-center' props: items: - label: Profile icon: i-heroicons-user - label: Billing icon: i-heroicons-credit-card - label: Settings icon: i-heroicons-cog content: align: start side: bottom sideOffset: 8 class: 'w-48' slots: default: | --- :u-button{label="Open" icon="i-heroicons-bars-3" color="gray" variant="outline"} :: ### Arrow Use the `arrow` prop to display an arrow on the DropdownMenu. ::component-code --- prettier: true ignore: - arrow - items - class external: - items class: 'justify-center' props: arrow: true items: - label: Profile icon: i-heroicons-user - label: Billing icon: i-heroicons-credit-card - label: Settings icon: i-heroicons-cog class: 'w-48' slots: default: | --- :u-button{label="Open" icon="i-heroicons-bars-3" color="gray" variant="outline"} :: ### Size Use the `size` prop to control the size of the DropdownMenu. ::component-code --- prettier: true ignore: - items - class - content.align external: - items class: 'justify-center' props: size: xl items: - label: Profile icon: i-heroicons-user - label: Billing icon: i-heroicons-credit-card - label: Settings icon: i-heroicons-cog content: align: start class: 'w-48' slots: default: | --- :u-button{size="xl" label="Open" icon="i-heroicons-bars-3" color="gray" variant="outline"} :: ::important The `size` prop will not be proxied to the Button, you need to set it yourself. :: ::note When using the same size, the DropdownMenu items will be perfectly aligned with the Button. :: ### Disabled Use the `disabled` prop to disable the DropdownMenu. ::component-code --- prettier: true ignore: - items - class external: - items class: 'justify-center' props: disabled: true items: - label: Profile icon: i-heroicons-user - label: Billing icon: i-heroicons-credit-card - label: Settings icon: i-heroicons-cog class: 'w-48' slots: default: | --- :u-button{label="Open" icon="i-heroicons-bars-3" color="gray" variant="outline"} :: ## Examples ### Control open state You can control the open state by using the `default-open` prop or the `v-model:open` directive. ::component-example --- name: 'dropdown-menu-open-example' class: 'justify-center' --- :: ::note In this example, press :kbd{value="O"} to toggle the DropdownMenu. :: ### With custom slot Use the `slot` property to customize a specific item. You will have access to the following slots: - `{{ item.slot }}`{lang="ts-type"} - `{{ item.slot }}-leading`{lang="ts-type"} - `{{ item.slot }}-label`{lang="ts-type"} - `{{ item.slot }}-trailing`{lang="ts-type"} ::component-example --- name: 'dropdown-menu-custom-slot-example' class: 'justify-center' --- :: ::tip{to="#slots"} You can also use the `item`, `item-leading`, `item-label` and `item-trailing` slots to customize all items. :: ### Extract shortcuts When you have some items with `kbds` property (displaying some [Kbd](/components/kbd)), you can easily make them work with the [defineShortcuts](/composables/define-shortcuts) composable. Inside the `defineShortcuts` composable, there is an `extractShortcuts` utility that will extract the shortcuts recursively from the items and return an object that you can pass to `defineShortcuts`. It will automatically call the `select` function of the item when the shortcut is pressed. ```vue ``` ::note In this example, :kbd{value="meta"} :kbd{value="E"}, :kbd{value="meta"} :kbd{value="I"} and :kbd{value="meta"} :kbd{value="N"} would trigger the `select` function of the corresponding item. :: ## API ### Props ::component-props --- ignore: - as - to - target - activeClass - inactiveClass - exactActiveClass - ariaCurrentValue - href - rel - noRel - prefetch - noPrefetch - prefetchedClass - replace - exact - exactQuery - exactHash - external --- :: ### Slots :component-slots ### Emits :component-emits ## Theme :component-theme