导航


HTML

CSS

JavaScript

浏览器 & 网络

版本管理

框架

构建工具

TypeScript

性能优化

软实力

算法

UI、组件库

Node

冷门技能

介绍:

一个公共数据管理工具。可以把一些共享的数据保存到vuex中,方便整个程序中任何组件直接获取或修改。

作用:

为了保存组件之间需要共享的数据。

vuex&props&data之间的区别

替代:

vuex 可以使用 localStorage 或者 sessionStorage 替代,在小项目中,能不使用 vuex 就不使用,没有必要。

⭐️ 基本使用

1. 运行 npm install vuex -S
2. src目录下面新建一个vuex的文件夹,vuex 文件夹里面新建一个store.js
// 在创建的store.js 中引入 vue、vuex
import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)

// 定义数据
var state = {
  count:1
}

// 包装数据(可以理解为store的计算属性)
var getters = { // 只负责对外提供数据,不负责修改。如果想要修改,请使用 mutation
  optCount: function(state) {
    return '当前累加值count是:' + state.count
  }
}

// 定义方法(改变state中的数据)
var mutations = {
  // 参数1:state状态 参数2:通过commit提交过来的参数,只能是一个,多个则使用对象形式{a:1,b:2}
  incCount(state, a){
    state.count += a
  }
}

// 异步请求
var actions = {
  //Action 函数接受一个与 store 实例具有相同方法和属性的 context 对象
  increment(context) {
    let a = context.state.a
    context.commit('incCount')
  },
  checkout({ commit, state }, payload) {
    commit('increment')
  }
}

// 暴露
const store = new Vuex.Store({
  state,
  mutations
})
export default store

3. 组建里面使用vuex
// 引入 store
import store from '../vuex/store.js';
// 获取vuex数据
this.$store.state.count
// or
this.$store.getters.optCount
// 更新vuex数据
this.$store.commit('incCount', 2);
// 异步更新
this.$store.dispatch('checkout', payload);

注意点

localStorage

存储:

localStorage.setItem('car', JSON.stringify(state.car));

获取:

// 一旦通过getItem没有取到数据会返回null
// 所以我们需要在null的情况下,给个数组字面量的字符串,否则JSON.parse(null)还是返回null
// 这不是我们想要的
var car = JSON.parse(localStorage.getItem("car") || '[]')

封装:

var storage = {
	set(key, value) {
    localStorage.setItem(key, JSON.stringify(value));
  }
  get(key) {
    return JSON.parse(localStorage.getItem(key) || '[]')
  }
	remove(key) {
    localStorage.removeItem(key);
  }
}

export default storage;