はじめに
kintoneの標準機能でできることは、今までの数々のアップデートによりできることがかなり増えてると思います。それに加え、プラグインなどのエコシステムも年々進化してきており、ノーコードでもやれることもたくさんあります。
しかし、ある一定以上の規模のものを扱おうとするとJavaScriptカスタマイズを用いたくなるシーンもまだまだあります。
kintoneでJavaScriptであまり制限なく介入できるのは、他のSaaSと比較してもかなり大きいメリットです。JavaScriptを利用できるということは、JavaScriptに関する今までの知識やライブラリなど、JavaScriptのエコシステムまでも取り込むことができます。
反面、JavaScript開発に慣れていない方にとっては、今までのJavaScriptの歴史もあり「JavaScriptはどう書くのがいいのか」ということが結構難しかったりします。
様々な書き方がある中でどういう書き方をすればいいか?一元管理してソースコードを管理したり、ファイル構成どうするかや、共通の関数などを作っていろんなアプリで使い回すにはどうするべきか、など色々考え出すと難しい面もあります。
そこで一つの考え方の参考になればと思い「目指せ!JavaScriptカスタマイズ中級者」という記事を執筆させてもらっています。
目指せ!JavaScriptカスタマイズ中級者シリーズについて
現時点では4記事の公開をしています。
それぞれ、主要な点を段階を踏みながら学習できるようにしているつもりです。下記に、各記事のURLと学べることについてまとめます。
-
目指せ!JavaScriptカスタマイズ中級者(1) 〜webpack編〜
まず、複数のアプリに対してJavaScriptを一元で管理できるよう、第一回では、Webpackを用いて複数のJavaScriptファイルをバンドルする方法などを解説しています。ディレクトリ構成の例も示しているので参考のひとつにしてもらえればと思います。
また、Webpackでバンドルしつつトランスパイルも行うことにより、JavaScriptの新しい記法を使ってもIEでも動かせるようにしています。JavaScriptは、ECMAScript 2015以降とそれ以前で大幅に進化しており、まだ試せてない方はぜひ新しい記法や機能も使えるようになればと思っています。 -
目指せ!JavaScriptカスタマイズ中級者(2) 〜Promiseのかわりにasync/await編〜
Promiseは概念的に少し難しいものだと思っています。この記事では、より直感的にコードを書けるasync/awaitを使った書き方について説明しています。
プロジェクトにもよるとおもいますが、どちらかというとasync/awaitが主流ではあるとおもいますので、公式リファレンスでは説明しきれていないasync/awaitに言及したいと思って書いた記事です。(IEでは動作しないので第一回のトランスパイル前提となっています) -
目指せ!JavaScriptカスタマイズ中級者(3) 〜自動で一括ファイルアップロード編〜
第一回で紹介した状態ですと手動でJavaScriptファイルをアップロードするまでになっているので、自動でアップロードできるようスクリプトを用意しました。 -
目指せ中級者!実践JavaScriptカスタマイズレベルアップ(4) 〜kintone REST API Client編〜
kintone rest api client の導入方法と使い方について説明した記事です。もちろん必ずしもkintone rest api clientを利用する必要はありませんが、気軽にレコードの全件取得ができたり、その他便利な使い方もできるので、今後カスタマイズしていく上では積極的に採用してもいいと思い、解説しています。 -
目指せ中級者!実践JavaScriptカスタマイズレベルアップ(5) 〜TypeScript編〜(準備中)
どこまでが中級者なのかというのはありますが、最終的には、TypeScript書けるようになれば、開発体験としてはかなりいいと思っています。TypeScriptはJavaScriptに型定義をできるようにしたもので、利用できるようになると型定義により未然にバグも防げます。例えば、複雑なサブテーブルの構造もTypeScriptでかけるようになれば、だいぶサクサクかけるようになりますので、ぜひTypeScriptの導入を広めるべく、現在記事を準備しております。
おわりに
kintoneを扱い始めた当初、もともとJavaScript開発がわからなかった自分なりに、試行錯誤してきました。
同じようにkintoneでJavaScriptにふれるようになり多少書けるようになったが、規模が大きくなるとよりよく書くにはどうするべきか、といった悩みを持つ方も少なからずいると思っています。上記の記事がその一つの参考になればいいと思っています。
「こういう場合どうするべきか」など上記記事で触れきれていない部分もあるとおもうので、何か要望等アレばコメントいただければ幸いです。