福岡でVR・アプリ開発をやっている株式会社OneSmallStepの@_takeshi_24です。
公開から2年が経ち、この記事の内容も少し古くなってきました。
Nuxt.jsやFirebaseを使って、サーバーレスでWebアプリケーションを開発する手順について、アドベントカレンダー「diffeasyCTO西の24(にし)日連続投稿チャレンジ Advent Calendar 2019」の中で、「Nuxt.jsとFirebaseとCloudFunctionsでWebアプリ開発」シリーズとして、連載していきます。
Nuxt.jsとFirebaseなどを使ってWebアプリケーション開発にチャレンジしたい方、是非Qiitaアカウントかtwitterをフォローしていただき、ツッコミやいいね!お願いします!
Nuxt.jsとは
公式ドキュメントに詳しく書いていますが、Vue.js アプリケーションを構築するためのフレームワークです。
サーバーサイドレンダリングするアプリケーションの開発のために必要な設定があらかじめセットされているのが特徴です。
Nuxt.jsには主に以下のパッケージが含まれています。
- Vue2・・・Vue本体です。
- Vue-Router・・・Vueアプリケーションでのルーティングを管理するパッケージです。
- Vuex・・・Vue版のFluxです。
- Vue Server Renderer・・・Vueアプリケーションをサーバーサイドレンダリングするためのパッケージです。
- Vue-Meta・・・Vueアプリケーションのメタ情報を管理するパッケージです。
サーバーサイドレンダリングとは?
Vue.jsなどでDOMの構築をクライアント側で行うと、サイトにアクセスした際に一瞬画面が表示されない状態になります。
サーバー側で初期状態のDOMレンダリングを完了した状態で返すことで、サイトにアクセスした際にすぐに画面を描画することができます。
これをサーバーサイドレンダリング(SSR)と呼びます。
Nuxt.js使ってみた
vue-cliでNuxtのプロジェクトを作成
では、早速使ってみましょう。
今回はスターターテンプレートを使って作成します。
テンプレートを利用するためには、テンプレートプロジェクトを自動生成してくれるツール「vue-cli」を利用します。
vue-cliがインストールされていない場合は、以下のコマンドを実行してvue-cliをインストールしてください。
npm install -g vue-cli
vue-cliがインストールされたら、以下のコマンドを実行すると、Nuxtのテンプレートプロジェクトが作成されます。
ここでは「sample」というプロジェクト名で作成します。
vue init nuxt-community/starter-template sample
プロジェクト名やプロジェクトの説明、作成者を入力します。
? Project name sample
? Project description Nuxt.js project
? Author takeshi
sampleディレクトリに、プロジェクトが作成されます。
以下のコマンドを実行して、必要なライブラリをインストールします。
cd sample
npm install
開発サーバーを起動します。
npm run dev
localhost:3000でNuxtのサンプルアプリが起動します。
> sample@1.0.0 dev /Users/takeshi/projects/sample/sample
> nuxt
nuxt:build App root: /Users/takeshi/projects/sample/sample +0ms
nuxt:build Generating /Users/takeshi/projects/sample/sample/.nuxt files... +1ms
nuxt:build Generating files... +49ms
nuxt:build Generating routes... +7ms
nuxt:build Building files... +21ms
nuxt:build Adding webpack middleware... +110ms
Build completed in 6.958s
DONE Compiled successfully in 6963ms 21:33:18
OPEN http://localhost:3000
とりあえず、画面出ました!
ページを追加する
Nuxt.jsではVue-Routerでルーティングを管理します。
従来Vue.jsでSPA作るときもVue-Routerを使っていました。
その際、componentを作成して、Vue-RouterでURIとcomponentをマッチングするための定義を記述していました。
Nuxt.jsでは、pagesディレクトリにページ用のcomponentを配置します。
pagesディレクトリに*.vueファイルを配置することで、自動でルーティングの定義を行ってくれます。
例えば、
/pages/users/index.vue
<template>
<section class="container">
<div>
<h1>usersのindexページです。</h1>
</div>
</section>
</template>
<script>
</script>
を作成するだけで、自動的に/usersのURIとマッチングしてくれて、
http://localhost:3000/users
にアクセスすると、作成した/pages/users/index.vueのページが表示されます。
Vuexを使う
VuexはVue.js版のFlux(状態管理ライブラリ)です。
従来のVue.jsではstore/index.js内で必要なmoduleをすべて読み込んで、ストアインスタンスをexportしていました。
Nuxt.jsでは2つのストアモードが用意されています。
従来同様のクラシックモードと、新たに導入されたモジュールモードです。
モジュールモードでは、storeディレクトリに配置された*.js ファイルがモジュールに変換されます。
サンプルとして、カウントアップするだけの単純なストアを作成します。
storeディレクトリにcounter.jsを作成します。
export const state = () => ({
count: 0
})
export const mutations = {
add (state) {
state.count += 1
}
}
countの状態をもっていて、それをカウントアップするためのaddという処理があります。
先ほどの、/pages/users/index.vueを改造して、このストアの処理を呼び出します。
<template>
<section class="container">
<div>
<h1>usersのindexページです。</h1>
<p>count={{count}}</p>
<button @click="addCount">カウントアップ</button>
</div>
</section>
</template>
<script>
export default {
computed: {
count () { return this.$store.state.counter.count }
},
methods: {
addCount (e) {
this.$store.commit('counter/add')
}
}
}
</script>
computed処理の中で、counterストアのcountの値を返しています。
this.$store.state.counter.count
「カウントアップ」ボタンがクリックされると、methodsのaddCount処理が実行され、counterストアのadd処理がコミットされています。
this.$store.commit('counter/add')
修正した画面を開いて、「カウントアップ」ボタンをクリックすると、counterストアのcountの状態が更新されているのがわかります。
#まとめ
一通り使ってみた感想です。
従来のVue.jsでSPAを作る際は、自由度があるが故に、自分でVue-Routerをもってきたり、Vuexをもってきたり、最初のプロジェクトを作る時にはいろいろ手探りしながらやっていました。
それらがNuxt.jsには最初から含まれているので、フロントエンド開発に慣れていない方でもすごくとっつきやすい印象です。
ルーティングが自動で生成されるのも手軽で良いですね。
公式ドキュメントに日本語で詳しく説明がありますので、書くことねーなー、と思いながらこの記事を書き進めました。
目標と期限を宣言し、共有し、繋がる達成.meもNuxt.jsで作っていますので、ぜひ使ってみてください!