selectのデザインをCSSとJavascriptでカスタマイズ

jQuery mobile などの大規模なプラグインを導入せずに
オリジナルデザインのセレクトボックスを設置するためのjQuery+CSSのソースをご紹介します。

動作サンプルはこちら。

フォーム要素の初期装飾をリセットできるCSS3のappearanceは、IE8以下でつかうことができませんが
このやり方なら、外形の装飾はIE6から最新のブラウザまで同じようにデザインを変えられます。
ただ、スマートフォン対応をがメインのため、展開したときのoption部分はデフォルトのままです。

実際のソース

大雑把に解説すると、本物のセレクトボックスは透明にしてクリック判定のためだけに配置しておいて
装飾部分は.innerのdivで代替しています。
javascriptでは、セレクトボックスで選択された値(選択された項目の表示文字列)を取得して
.innerの要素に表示させています。

<br />
&lt;div class=&quot;custom-selectbox&quot;&gt;<br />
	&lt;div class=&quot;inner&quot;&gt;&lt;span&gt;&lt;/span&gt;&lt;/div&gt;<br />
	&lt;select name=&quot;month&quot;&gt;<br />
		&lt;option value=&quot;&quot; selected=&quot;selected&quot;&gt;--&lt;/option&gt;<br />
		&lt;option value=&quot;1&quot;&gt;January&lt;/option&gt;<br />
		&lt;option value=&quot;2&quot;&gt;February&lt;/option&gt;<br />
		&lt;option value=&quot;3&quot;&gt;March&lt;/option&gt;<br />
		&lt;option value=&quot;4&quot;&gt;April&lt;/option&gt;<br />
		&lt;option value=&quot;5&quot;&gt;May&lt;/option&gt;<br />
		&lt;option value=&quot;6&quot;&gt;June&lt;/option&gt;<br />
		&lt;option value=&quot;7&quot;&gt;July&lt;/option&gt;<br />
		&lt;option value=&quot;8&quot;&gt;August&lt;/option&gt;<br />
		&lt;option value=&quot;9&quot;&gt;September&lt;/option&gt;<br />
		&lt;option value=&quot;10&quot;&gt;October&lt;/option&gt;<br />
		&lt;option value=&quot;11&quot;&gt;November&lt;/option&gt;<br />
		&lt;option value=&quot;12&quot;&gt;December&lt;/option&gt;<br />
	&lt;/select&gt;<br />
&lt;/div&gt;<br />

 

<br />
.custom-selectbox {<br />
	position: relative;<br />
}<br />
	.custom-selectbox select {<br />
		position: absolute;<br />
		top: 0;<br />
		left: 0;<br />
		z-index: 1;<br />
		width: 240px;<br />
		height: 36px;<br />
		opacity: 0;<br />
	}<br />
	.custom-selectbox .inner {<br />
		position: relative;<br />
		z-index: 0;<br />
		box-sizing: border-box;<br />
		border: 1px solid #000;<br />
		padding: 0 12px;<br />
		width: 240px;<br />
		height: 36px;<br />
		font-size: 14px;<br />
		line-height: 36px;<br />
	}<br />
	.custom-selectbox .inner:before,<br />
	.custom-selectbox .inner:after {<br />
		content: '';<br />
		position: absolute;<br />
		display: block;<br />
	}<br />
	.custom-selectbox .inner:before {<br />
		top: 0;<br />
		right: 0;<br />
		bottom: 0;<br />
		width: 24px;<br />
		background: #000;<br />
	}<br />
	.custom-selectbox .inner:after {<br />
		top: 50%;<br />
		right: 7px;<br />
		margin-top: -3px;<br />
		width: 0;<br />
		height: 0;<br />
		border: solid transparent;<br />
		border-top-color: #fff;<br />
		border-width: 5px 5px 0 5px;<br />
	}<br />

<br />
custom_selectbox = function(select, obj){<br />
	var set_selectbox = function(){<br />
		var value = jQuery(this).find('option:selected').html();<br />
		jQuery(select).find(obj).find('span').html(value);<br />
	}<br />
	jQuery(select).find('select').each(set_selectbox).on('change', set_selectbox);<br />
}</p>
<p>jQuery(function(){<br />
	custom_selectbox('.custom-selectbox', '.inner');<br />
});<br />

この仕組は、この前おぼえたAdobeのEdge InspectでjQuery mobileのデモを解析し
それを大々的に参考にして簡略化したものです。
独自のアイデアではないので、たいへん恐縮です。
jQuery mobile開発者の皆様、勉強になりました。ありがとうございます!

関連記事