How can I limit the number of shown options in an HTML <select>
drop down?
For example:
<select>
<option value="1">1</option>
<option value="2">2</option>
...
<option value="20">20</option>
</select>
How can I get the browser to show only the first five options and scroll down for the rest?
It is not possible to limit the number of visible elements in the select dropdown (if you use it as dropdown box and not as list).
But you could use javascript/jQuery to replace this selectbox with something else, which just looks like a dropdown box. Then you can handle the height of dropdown as you want.
jNice would be a jQuery plugin which has such features. But there also exists many alternatives for that.
Use
size
attribute of<select>
;the size attribute matters, if the size=5 then first 5 items will be shown and for others you need to scroll down..
You can use the
size
attribute to make the<select>
appear as a box instead of a dropdown. The number you use in thesize
attribute defines how many options are visible in the box without scrolling.You can’t apply this to a
<select>
and have it still appear as a drop-down list though. The browser/operating system will decide how many options should be displayed for drop-down lists, unless you use HTML, CSS and JavaScript to create a fake dropdown list.You can try this
It worked for me
Raj_89 solution is the closest to being valid option altough as mentioned by Kevin Swarts in comment it is going to break IE, which for large number of corporate client is an issue (and telling your client that you won't code for IE "because reasons" is unlikely to make your boss happy ;) ).
So I played around with it and here is the problem: the 'onmousedown' event is throwing a fit in IE, so what we want to do, is to prevent default when user clicks the dropdown for the first time. It is important this is only time we do this: if we prevent defult on the next click, when user makes his pick, the onchange event won't fire.
This way we get nice dropdown, no flicker, no breaking down IE - just works... well at least in IE10 and up, and latest relases of all the other major browsers.
Here is the fiddle: https://jsfiddle.net/88cxzhom/27/
Few more things to notice: 1) The absolute positioning and setting z-index is helpful to avoid moving other elements when the options are displayed. 2) Use 'currentTarget' property - this will be the select element across all browsers. While 'target' will be select in IE, the rest will actually allow you to work with option.
Hope this helps someone.