--- title: bootstrap4のスタイルをベースにdatatablesを爆速で利用してみた(CDN利用) tags: CSS DataTables jQuery bootstrap4 cdn author: shinataka slide: false --- htmlでtable表記をする際になにかと便利なのがdatatablesですよね。 少し前に某サイトで利用する目的で実装したのですが、最近また別件で実装する機会があったので せっかくだから`Bootstrap4`をベースに使ってみようと思い [元サイト](https://datatables.net/) を見てみたら bootstrap4 用のcssとjsがあるじゃありませんか!! ということで、今回はdatatablesをbootstrap4ベースで利用してみようというお話です。 実質 **15分程度** でステキなテーブル表示ができました。 が、少しだけハマったところがあったので注意点も含めてまとめたいと思います。 ### 前提 --- - 全ての外部ファイル(CSS,JS)は **CDN** を利用する。 - datatablesのロケールは日本語にする。(datatablesのプラグインを使う。) - jqueryは **3.2.1** を使用する。(ちゃんとdatatablesの手前で宣言しておいてね。) ### DataTablesってなに? --- 一応datatables知らないよって人のために簡単にdatatablesの機能を簡単にまとめてみます。 一言でいうとtableにポピュラーな機能を付加してくれるステキなjqueryの拡張機能です。 - tableタグそのものに手を加える必要がない。 - jqueryのID指定 `#("table").datatable();` をするだけで以下の機能が付加される。 - 自動的に付加される機能は以下 - ページネーション - 表示件数の変更 - カラムソート - 部分検索 ということで実際に実装してみましょう。 ### bootstrap4、jQuery3の宣言 --- 2017/11時点ではまだbeta版ですが気にせず使っていきましょう。 [bootstrap本家サイト](http://getbootstrap.com/docs/4.0/getting-started/introduction/) に書いてある通りに宣言します。 ```html:header部分 ``` jsの宣言は `` の手前に。 ```html ``` ### datatablesの宣言 --- 準備が整ったので、datatablesの宣言をします。 [datatablesのサイト](https://datatables.net/)にアクセスし、[CDNのページ](https://cdn.datatables.net/)に遷移します。 **bootstrap4** のトグルボタンを押下して選択したら、その下にある**Release**部分のソースをコピペします。 ※宣言はbootstrap4,jQuery3の後にそれぞれ追加してください。 ```html:header部分(cssの宣言) ``` ```html:bodyの最後(jsの宣言) ``` ### datatablesの日本語化 --- 全ての宣言を終えたらちょっとだけカスタマイズします。 ```html:日本語化(jsの宣言の後に追加) ``` ### table属性を記述する。 上記全てが完了したらtableタグを書きます。 ```html:tableタグ(bodyの中に記述)
No 氏名 メールアドレス
1 ほげほげ太郎 hogehoge@example.com
2 ほげふが次郎 hogefuga@example.com
``` ### ハマった点 --- これでもう完成!と思いブラウザで表示させてみたら・・・あれ?テーブル表示以外何にも出ない・・・ デバッガツールのコンソールを見てみたら以下のエラーが。 ``` TypeError: $.ajax is not a function ``` ajaxなんて使ってないのに・・・と思ったのですが、datatablesはajaxでデータのやり取りをする機能がデフォでついているので、jQueryの初期化で怒られてました。 何かいけないのか調べていたところ、jqueryの宣言を見ると・・・ ``` jquery-3.2.1.slim.min.js ``` ん? **slim**? minは良いとしてslimってなんぞ?? ググってみたところ このslimっていうのは余分なjQueryの機能をそぎ落としてパフォーマンスを向上させている版で、ajax部分の記述がどうやらなくなっているらしいです。 --- **参考にさせて頂いたサイト** [TypeError: $.ajax is not a function エラーが出た時の対策(jQuery 3.x)](http://develtips.com/javascript/118) --- ということで、改めて[jQueryCDN](http://code.jquery.com/)のサイトからslimじゃないバージョンの宣言をコピペします。 ```html:変更前 ``` ↓ ```html:変更後 ``` おぉ、できた!! ### 完成 --- 完成形のソースは以下です。そのままコピペして頂ければローカル環境でも見られると思います。 ```html:datatable.html datatebles site
No 氏名 メールアドレス
1 ほげほげ太郎 hogehoge@example.com
2 ほげふが次郎 hogefuga@example.com
``` 以上です。 html1枚ペラで15分程度でこのクオリティ! もちろんこの後はajaxでバックエンドと通信したり、実際のレコード部分はレスポンスデータを流し込んだりしますが、ガワを爆速で用意できるのは素晴らしいですね。 datatablesは高機能なので色々とカスタマイズしてみると良いと思います。