HTMLSelectElement: showPicker() method
Limited availability
This feature is not Baseline because it does not work in some of the most widely-used browsers.
The HTMLSelectElement.showPicker()
method displays the browser picker for a select
element.
This is the same picker that would normally be displayed when the element is selected, but can be triggered from a button press or other user interaction.
Syntax
showPicker()
Parameters
None.
Return value
None (undefined
).
Exceptions
InvalidStateError
DOMException
-
Thrown if the element is not mutable, meaning that the user cannot modify it and/or that it cannot be automatically prefilled.
NotAllowedError
DOMException
-
Thrown if not explicitly triggered by a user action such as a touch gesture or mouse click (the picker requires Transient activation).
NotSupportedError
DOMException
-
Thrown if the element associated with the picker is not being rendered.
SecurityError
DOMException
-
Thrown if called in a cross-origin iframe.
Security considerations
Transient user activation is required. The user has to interact with the page or a UI element in order for this feature to work.
The method is only allowed to be called in same-origin iframes; an exception is thrown if this is called in a cross-origin iframe.
Examples
Feature detection
The code below shows how to check if showPicker()
is supported:
if ("showPicker" in HTMLSelectElement.prototype) {
// showPicker() is supported.
}
Launching the picker
This example shows how to use a button to launch the picker for a <select>
element with two options.
HTML
<p>
<select>
<option value="1">One</option>
<option value="2">Two</option>
</select>
<button type="button">Show Picker</button>
</p>
JavaScript
The code gets the <button>
and adds a listener for its click
event.
The event handler gets the <select>
element and calls showPicker()
on it.
const button = document.querySelector("button");
button.addEventListener("click", (event) => {
const select = event.srcElement.previousElementSibling;
try {
select.showPicker();
} catch (error) {
window.alert(error);
}
});
Specifications
Specification |
---|
HTML # dom-select-showpicker |
Browser compatibility
BCD tables only load in the browser