バニラJavaScriptでリッチなセレクトメニュー(プルダウン)を実装できる「Tom Select」の利用方法
先日バニラJavaScriptでリッチなセレクトメニュー(プルダウン)を実装できる「Choices.js」の利用方法をメモしたがCSSに若干癖があった。他に似たようなライブラリが無いか探したところ「Tom Select」がCSSに癖も無く使いやすそう。以下にサンプルと利用方法をメモ。
Choices.js
公式サイト
GitHub
https://github.com/orchidjs/tom-select
CDN
CDNで使う場合は以下を記述する。
<script src="https://cdn.jsdelivr.net/npm/tom-select@2.3.1/dist/js/tom-select.complete.min.js"></script> <link href="https://cdn.jsdelivr.net/npm/tom-select@2.3.1/dist/css/tom-select.min.css" rel="stylesheet">
サンプル
https://taitan916.info/sample/tom-select/
実装方法
ソースコード
<div class="section">
<div>単一選択</div>
<select class="tom_1">
<option value="1">大トロ</option>
<option value="2">マグロ</option>
<option value="3">ねぎとろ</option>
<option value="4">中トロ</option>
<option value="5">サーモン</option>
</select>
</div>
<div class="section">
<div>複数選択可</div>
<select class="tom_2">
<option value="1">大トロ</option>
<option value="2">マグロ</option>
<option value="3">ねぎとろ</option>
<option value="4">中トロ</option>
<option value="5">サーモン</option>
</select>
</div>
<div class="section">
<div>複数選択可&ページ表示時にサーモンを選択済み</div>
<select class="tom_3">
<option value="1">大トロ</option>
<option value="2">マグロ</option>
<option value="3">ねぎとろ</option>
<option value="4">中トロ</option>
<option value="5" selected>サーモン</option>
</select>
</div>
<style>
.section{
margin: 10px 0;
}
</style>
<script src="https://cdn.jsdelivr.net/npm/tom-select@2.3.1/dist/js/tom-select.complete.min.js"></script>
<link href="https://cdn.jsdelivr.net/npm/tom-select@2.3.1/dist/css/tom-select.min.css" rel="stylesheet">
<script>
const option_1 = {
items: [], //ページ表示時に未選択状態
placeholder: '選択してください', //プレースホルダー
hidePlaceholder: true, //1つ以上選択した場合にプレースホルダー非表示
};
const option_2 = {
items: [],
plugins: ['remove_button'], //未選択ボタンの表示
maxItems: 3, //最大選択数
placeholder: '選択してください',
hidePlaceholder: true,
};
const option_3 = {
plugins: ['remove_button'],
maxItems: 3,
placeholder: '選択してください',
hidePlaceholder: true,
};
const tom_1 = new TomSelect('.tom_1', option_1);
const tom_2 = new TomSelect('.tom_2', option_2);
const tom_3 = new TomSelect('.tom_3', option_3);
</script>
所感
「Tom Select」の方はCSSを指定しなくてもそのまま使っていけそう。またデザイン的にもこっちの方が個人的には好きかも。
関連記事
-
-
JavaScriptでオブジェクトをzlib圧縮してCookieに保存できる「zcookies」ライブラリの利用方法
あるシステムでCookieを保存している部分があった。ただ、日本語を保存している ...
-
-
円形のプログレスバーをprogressbar.jsで実装する方法
円形のプログレスバーを実装したかった。CSSだったり画像を用いたりする方法もあっ ...
-
-
バニラJavaScript対応の日時ピッカー「Flatpickr」ライブラリの利用方法
サイト内に日時ピッカーを実装する場合、jQueryの「DateTimePicke ...
-
-
表示範囲を自由に変更可能な折れ線グラフが表示できるJSライブラリ amCharts の使用方法
どこかのサイトを閲覧していた際に、恐らくはJavaScriptのライブラリで描写 ...
-
-
横スクロール可能な要素を視覚的に分かりやすくする「ScrollHint」ライブラリの利用方法
横長のtableを設置し、CSSのoverflowで横スクロール可能にしてもユー ...