#はじめに
データが大量にあるので複数のDBで管理しており、どこのDBを参照するのか選択させて保持しておきたい場面があり、Vuexを調べて使ってみたのでその備忘録です。
なにかおかしな点や、もっとこうしたほうがいいよ~等あればコメントお願いします!
#Vuexとは?
Vue.js アプリケーションのための状態管理パターン + ライブラリです。
公式の説明がわかりやすいです。公式最高。
#使い方
##インストール
以下のコマンドでインストールできます。
#npm
npm install vuex --save
#yarn
yarn add vuex
##ストアを有効化する
Vuex ストアは Nuxt.js に付属していてすぐに使えますが、デフォルトでは無効化されています。
nuxtのプロジェクト内にstore
というディレクトリがあります。(デフォルトでREADME.md
が入っています。)このディレクトリ内に隠しファイルやREADME.md
ではないファイルが含まれていたら、ストアが有効化されます。
今回はdbState.js
というファイルを作成しました。
##store/jsのファイルを編集
以下のように編集してみました。
//1.データの設定
export const state = () => ({
selectDb: null
});
//2.データの更新
export const mutations = {
setDb(state, db) {
state.selectDb = db;
}
};
//3.データの取得
export const getters = {
getDb(state) {
return state.selectDb;
}
};
1.データの設定
このjsファイル内で持つデータを設定します。vueファイルで言うところのdata(){ return { } }
の中です。
今回はDBを選択させたいのでselectDbとし、デフォルトをnullにしました。
2.データの更新
mutations
(ミューテーション)は、Vuex のストアの状態を変更できる唯一の方法です。
Vuex の状態(state)を第1引数として取得し、実際に状態の変更を行うので、第1引数をstate
、選択したDB情報を第2引数をdb
としました。
3.データの取得
このjsファイル内で持つデータを実際に呼び出したいときに使用します。mutations
に書くこともできますが、ゲッターに書くことでストアの算出プロパティと考えることができるので、分けて書いてみました。
##.vueファイルを編集
<script>
// 呼び出し
computed: {
selectedDb() {
return this.$store.getters['dbState/getDb']
}
},
// 更新
methods: {
selectDb(db) {
this.$store.commit('dbState/setDb', db)
}
},
</script>
呼び出しは this.$store.getters['ファイル名/関数名']
更新は this.$store.commit('ファイル名/関数名', 第2引数)
と書くことで使用できます。
#情報を永続化する
vuexでページ遷移後も情報を保持することができましたが、リロードするとデータが消えてしまいました。stateがリセットされてしまうらしい。。。
vuex-persistedstate
というプラグインを使うとstateの情報を永続化できるらしいので使ってみます。
##vuex-persistedstateをインストール
以下のコマンドでインストールできます。
# npm
npm install --save vuex-persistedstate
# yarn
yarn add vuex-persistedstate
##プラグインの設定
###plugins/persistedstate.jsを編集
pluginsに「persistedstate.js」というファイルを作成し、以下のように書きました
import createPersistedState from 'vuex-persistedstate'
export default ({ store }) => {
createPersistedState({
key: '任意の名前',
storage: window.sessionStorage
})(store)
}
key
はストレージキーです。デフォルトは、vuexになっているので基本的に指定しましょう。
storage
は、ストレージの種類です。デフォルトはローカルストレージです。
storage
は使用用途によって分けたほうがよさそうです。
ストレージ |
storage プロパティの値 |
違い |
---|---|---|
ローカルストレージ | window.localStrage | 意図的に消さない限りずっと残る |
セッションストレージ | window.sessionStrage | セッションが切れたとき、タブやブラウザを閉じたときにリセットされる |
###nuxt.config.jsを編集
以下のように書きました。
plugins: [
{ src: '~/plugins/persistedstate.js', ssr: false}
],
##注意点
データの永続化というくらいですから、ずっと残ってしまうトラブルも発生します。
今回はsessionStrag
を使用したのでセッションが切れたり、タブやブラウザを閉じたら消えますが、そうしない場合は情報が残ってしまいます。ステートを初期化するミューテーションを作成して、ログアウト時などに毎回呼び出すなど対策が必要です。
##永続化参考サイト
参考にしたサイト載せておきます
【Nuxt.js】storeを永続化する
vuexでリロードされても情報を永続化できるvuex-persistedstateの使い方
【Vue】リロードしても大丈夫。そう、vuex-persistedstateならね。
#追記
2021.09.14 追記:
自分のこの記事を参考に、別のプロジェクトで利用しようとしたらエラーが2つでた。
vue.runtime.esm.js?2b0e:619 [Vue warn]: The client-side rendered virtual DOM tree is not matching server-rendered content. This is likely caused by incorrect HTML markup, for example nesting block-level elements inside <p>, or missing <tbody>. Bailing hydration and performing full client-side render
client.js?06a0:103 TypeError: Cannot read properties of undefined (reading 'toLowerCase')
調べたところ、ローカルストレージはブラウザ(クライアントサイド)の機能のため、Nuxt.jsのモードをSSR(サーバサイドレンダリング)ではなくSPA(シングルページアプリケーション)に変更しないと動かないらしい
nuxt.config.js
ファイルでmode
の設定をspa
に変更することで治りました。
export default {
mode: 'spa', // ここをuniversalからspaに変更
/*
** Headers of the page
*/
head: {
titleTemplate: '%s - ' + process.env.npm_package_name,
~略~
}
ただこれが最善なのかはわかりませんが。。。別の解決法が分かる方よかったらコメントいただけると嬉しいです。
#さいごに
今回は自分が今使うにあたって必要な最低限についてのみでしたが、誰かの参考になれば嬉しいです。
最後まで読んでいただきありがとうございます!