lab.jsは心理学実験・調査を実施するためのJavaScriptライブラリです。JavaScriptライブラリとはJavaScriptというプログラミング言語において利用できる様々な関数の集合です。関数とは,任意に入力に対して特定の処理を行いその結果を出力する命令のことです。
<aside> 💡 関数をポケモンで例えると? 関数をポケモンで例えると,関数は技にあたります。100万ボルトという技であれば「ピカチュウ,100万ボルトだ!」というポケモントレーナーの音声入力に対して,ピカチュウが100万ボルトの発動準備(電気を起こしたりとか?)という内部処理を行い,100万ボルトの発動という結果が出力されるというわけです。このように関数を捉えると,関数の集合であるライブラリは特定の属性の技マシンのセット(電気技の色々な技マシンを集めたもの)と言えるかもしれません。
</aside>
lab.js自体はJavaScriptライブラリであるため,lab.jsによる実験・調査の作成にはプログラミングが必要です。しかし,GUI(Graphical User Interface; グラフィカルユーザーインターフェース)でlab.jsを用いたプログラムを作成できるウェブアプリケーションとして,lab.js Builderが提供されています。GUIとは,名の通りに視覚的に情報が表示され,マウスなどによって直感的に操作可能なインターフェースです。例えば,ExcelやWordなどはGUIにあたります。このlab.js Builderを利用することで視覚的に情報を確認しながら,マウス操作などでlab.jsによる実験・調査を作成することができます。
ウェブアプリケーションとは,インターネットブラウザ(Edge, Chrome, Safariなど)で利用できるアプリケーションを指します。ウェブアプリケーションは,コンピュータにソフトウェアをインストールすることなく利用でき,異なるコンピュータ(自宅,大学など)でも同一の環境で利用することができます。
このように,lab.js Builderを利用すれば,プログラミング不要,ソフトウェアインストール不要で,どこでも心理学実験・調査を無料で作成できるというわけです。そこで,これからlab.js Builderを使った様々な実験・調査の作成方法を紹介していきます。なお,lab.js Builderはすべて英語なので,最初はとっつきにくいかもしれませんが,使っていくうちに慣れていきます。安心してください。
lab.js Builderを使う前に,lab.jsが実験・調査を実施している仕組みをすこし紹介します。冒頭で述べたように,lab.jsはjavaScriptライブラリなので,javaScriptの機能によって実験・調査を実施しています。javaScriptの働きの1つにhtmlやcssを書き換えるというものがあり,これを利用しています。htmlやcssというのは,ウェブページの内容や見た目を制御する言語(マークアップ言語)です。皆さんが普段閲覧しているウェブページの多くはhtmlやcssによって構築されています。この関係をまとめたものが以下の図です。
javaScript(含むlab.js)によって,ウェブページを動的に書き換えることで実験・調査を行うというわけです。それぞれのプログラミング言語の役割は以下のようになっています。
例えば,「画面中央に文字を出して,10秒経ったら消える」という動作を行う場合は以下の流れで実現しています。