--- github: true description: Display a select menu with advanced features. headlessui: label: 'Listbox' to: 'https://headlessui.com/vue/listbox' --- ## Usage The SelectMenu component renders by default a [Select](/forms/select) component and is based on the `ui.select` preset. You can use most of the Select props to configure the display if you don't want to override the default slot such as [size](/forms/select#size), [placeholder](/forms/select#placeholder), [appearance](/forms/select#appearance), [icon](/forms/select#icon), [disabled](/forms/select#disabled), etc. Like the Select component, you can use the `options` prop to pass an array of strings or objects. ::component-example #default :select-menu-example-basic{class="max-w-[12rem] w-full"} #code ```vue ``` :: You can use the `multiple` prop to select multiple values but you have to override the `#label` slot and handle the display yourself. ::component-example #default :select-menu-example-multiple{class="max-w-[12rem] w-full"} #code ```vue ``` :: You can also override the default slot entirely. ::component-example #default :select-menu-example-button{class="max-w-[12rem] w-full"} #code ```vue ``` :: You can pass an array of objects to `options` and either compare on the whole object or use the `by` prop to compare on a specific key. You can configure which field will be used to display the label through the `option-attribute` prop that defaults to `label`. ::component-example #default :select-menu-example-objects{class="max-w-[12rem] w-full"} #code ```vue ``` :: ### Icon Use any icon from [Iconify](https://icones.js.org) by setting the `icon` prop by using this pattern: `i-{collection_name}-{icon_name}`. Use the `trailingIcon` prop to set a different icon or change it globally in `ui.select.default.trailingIcon`. Defaults to `i-heroicons-chevron-down-20-solid`. Use the `selectedIcon` prop to set a different icon or change it globally in `ui.selectMenu.default.selectedIcon`. Defaults to `i-heroicons-check-20-solid`. ::component-card --- baseProps: class: 'max-w-[12rem] w-full' placeholder: 'Select a person' options: ['Wade Cooper', 'Arlene Mccoy', 'Devon Webb', 'Tom Cook', 'Tanya Fox', 'Hellen Schmidt', 'Caroline Schultz', 'Mason Heaney', 'Claudie Smitham', 'Emil Schaefer'] props: icon: 'i-heroicons-magnifying-glass-20-solid' excludedProps: - icon --- :: ### Search Use the `searchable` prop to enable search. This will use Headless UI [Combobox](https://headlessui.com/vue/combobox) component instead of [Listbox](https://headlessui.com/vue/listbox). ::component-card --- baseProps: class: 'max-w-[12rem] w-full' placeholder: 'Select a person' options: ['Wade Cooper', 'Arlene Mccoy', 'Devon Webb', 'Tom Cook', 'Tanya Fox', 'Hellen Schmidt', 'Caroline Schultz', 'Mason Heaney', 'Claudie Smitham', 'Emil Schaefer'] props: searchable: true --- :: ## Props :component-props ## Preset :component-preset