ホームページ > ウェブフロントエンド > Vue.js > Vue における Vuex 状態管理とは何ですか?またその使用方法は何ですか?

Vue における Vuex 状態管理とは何ですか?またその使用方法は何ですか?

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
リリース: 2023-06-11 13:29:00
オリジナル
807 人が閲覧しました

Vue における Vuex 状態管理とは何ですか?またその使用方法は何ですか?

Vue は人気のあるフロントエンド フレームワークであり、その使いやすさと強力な機能により、プロジェクトで広く使用されています。フロントエンドプロジェクトが大規模化、複雑化するにつれ、データ管理はますます困難になり、特にステータス管理が重要になります。 Vue の状態管理ツールとして、Vuex はアプリケーションの状態をより適切に整理および管理し、コードの保守性を向上させるのに役立ちます。この記事では、Vuex 状態管理の基本概念と使用法を紹介し、読者が Vuex 状態管理の役割と実際の応用を理解できるようにします。

1. Vuex 状態管理の基本概念

  1. State

状態ストレージは Vuex の中核部分であり、コンポーネントの状態間の共有情報を保存するために使用されます。 。 State のデータ構造は配列、オブジェクトなどにすることができますが、コンポーネントのデータとは異なり、State データはグローバルです。 State のデータは Store オブジェクトによって管理され、プロジェクト内で簡単にアクセスして操作できます。

  1. Getter

Getter は、State の計算されたプロパティと考えることができます。コンポーネントでは、Getter を通じて State オブジェクトの変数にアクセスできます。Getter はいくつかの計算を定義します。この関数は、Vue の計算プロパティに相当する State のデータを取得するために使用されます。状態管理でゲッターを使用すると、複雑な計算ロジックをカプセル化し、複数のコンポーネント間での共有と再利用が容易になります。

  1. Mutation

Mutation は、State を更新し、State 内のデータを変更するためのいくつかの関数を定義します。同期操作のみを実行できます。状態への変更はミューテーションを経由する必要があるため、これによりデータへの変更を追跡し、状態をリアルタイムで更新できることが保証されます。 Mutation の使用も非常に簡単で、コンポーネント内で $store.commit メソッドを呼び出し、対応する Mutation 名を渡すだけです。

  1. Action

Action は、ビジネス ロジックを処理する非同期操作です。HTTP リクエスト、setTimeout、その他の非同期操作など、任意の非同期操作を含めることができます。非同期操作が必要な場合、アクションはミューテーションに送信され、ミューテーションは同期操作を実行して状態を更新します。アクションとミューテーションの違いは、アクションには非同期操作を含めることができることです。アクションは他のアクションやミューテーションを呼び出すこともできます。

  1. Module

Module を使用すると、ストアをモジュールに分割でき、各モジュールは独自の State、Mutation、Action、Getter メソッドを持つことができます。これにより、ストアがより整理され、コードの可読性が向上し、チームのコラボレーションが容易になります。 Vuex のモジュール化メカニズムは ES6 のモジュール化と似ており、モジュール化を使用すると、ストアを簡単に拡張および変更できます。

2. Vuex 状態管理の使用方法

  1. Vuex のインストールと参照

Vuex を使用する前に、Vuex のインストールと参照が必要です。

インストール方法:

npm install vuex --save
ログイン後にコピー

参考方法:

import Vuex from 'vuex'
Vue.use(Vuex)
ログイン後にコピー
  1. ストアの作成

Vuex 状態管理を使用する場合、最初に必要なものStore オブジェクトを作成します。これは、アプリケーション全体の状態を含むシェルである必要があります。 Store オブジェクトの作成も非常に簡単で、State、Mutation、Action、Getter などのモジュールを組み合わせるだけです。

import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex)

// 定义应用的初始状态
const state = {
  count: 0
}

// 定义 Mutation,处理 State
const mutations = {
  increment (state) {
    state.count++
  },
  decrement (state) {
    state.count--
  }
}

// 定义 Action,处理异步操作
const actions = {
  incrementAction ({ commit }) {
    setTimeout(() => {
      commit('increment')
    }, 1000)
  }
}

// 定义 Getter,获取 State 中的数据
const getters = {
  getCount: state => state.count
}

// 创建 Store 对象
export default new Vuex.Store({
  state,
  mutations,
  actions,
  getters
})
ログイン後にコピー
  1. コンポーネントでストアを使用する

ストアを作成したら、コンポーネントで使用できます。コンポーネントで Store を使用する方法は、this.$store.xxx を通じてそれを呼び出すことです。xxx には、State、Mutation、Action、または Getter を指定できます。

<template>
  <div>
    <p>当前的数字为:{{count}}</p>
    <button @click="increment">增加</button>
    <button @click="decrement">减少</button>
  </div>
</template>

<script>
export default {
  computed: {
    count () {
      return this.$store.getters.getCount
    }
  },
  methods: {
    increment () {
      this.$store.commit('increment')
    },
    decrement () {
      this.$store.commit('decrement')
    }
  }
}
</script>
ログイン後にコピー
  1. コンポーネントでのモジュールの使用

アプリケーションがますます大きくなると、State、Mutation、Action、Getter の使用が少し面倒になります。コードをより適切に整理するために、コードをモジュールにマージできます。

const appModule = {
  state: {
    count: 0
  },
  mutations: {
    increment (state) {
      state.count++
    },
    decrement (state) {
      state.count--
    }
  },
  actions: {
    incrementAction ({ commit }) {
      setTimeout(() => {
        commit('increment')
      }, 1000)
    }
  },
  getters: {
    getCount: state => state.count
  }
}

export default new Vuex.Store({
  modules: {
    appModule: appModule
  }
})
ログイン後にコピー

その後、コンポーネント内で次のように使用できます:

<template>
  <div>
    <p>当前的数字为:{{count}}</p>
    <button @click="increment">增加</button>
    <button @click="decrement">减少</button>
  </div>
</template>

<script>
export default {
  computed: {
    count () {
      return this.$store.getters['appModule/getCount']
    }
  },
  methods: {
    increment () {
      this.$store.commit('appModule/increment')
    },
    decrement () {
      this.$store.commit('appModule/decrement')
    }
  }
}
</script>
ログイン後にコピー

上記は、この記事での Vuex 状態管理の紹介です。読者の参考になれば幸いです。実際のアプリケーションでは状態管理の重要性は無視できず、Vuex を適切に使用することで開発をより効率的かつスムーズに行うことができます。

以上がVue における Vuex 状態管理とは何ですか?またその使用方法は何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート