Vue中的状态管理器 - Vuex

我们知道vue是组件式开发的,当你的项目越来越大后,每个组件背后的数据也会变得越来越难以理顺,

这个时候你就可以考虑使用vuex了。

备注: 官方建议小项目不要使用,引入vuex会带来新的概念和模式,这对于新手而言理解上本身有难度,而且小项目中vuex发挥的功效确实不怎么明显,

反而增加了开发难度,就像后端项目中常说的 过度设计。

说了这么多,下面介入正题(以下讲解需要一个空的vue项目,推荐使用 vue-cli 创建,快速搭建一个vue开发环境 ):

vuex的作用就是作为一个数据仓库(store),把多个组件的背后的数据都放到store中,然后所有组件通过约定的方式去读取数据和修改数据。

这一句话就概括完了。没有想象的那么复杂。注意,这句话里面一个关键词叫 约定,下面来说说有那些约定:

在将约定之前,首先还是要知道怎么定义一个仓库(store),进入项目然后  vue add vuex 。

通过这条命令,vue-cli 帮我们创建了一个 store.js 的文件,并自动在根组件中引入了store,具体变化如下:

main.js 文件中自动变化了两处

import Vue from ‘vue‘
import App from ‘./App.vue‘
import store from ‘./store‘ #【引入store文件】

Vue.config.productionTip = false

new Vue({
  store, #【在根组件中引入了store】
  render: h => h(App)
}).$mount(‘#app‘)

现在我们编辑一下 store.js 文件:

import Vue from ‘vue‘
import Vuex from ‘vuex‘
Vue.use(Vuex)
export default new Vuex.Store({
  state: {
      user: {
        name: ‘张三‘, sex: ‘男‘
      }
  },
  mutations: {
    change_name (state,payload) {
      state.user.name = payload.new_name
    },
    change_sex (state,payload) {
      state.user.sex = payload.new_sex
    }
  },
  actions: {
    change_sex_by_action (context,payload) {
      setTimeout(() => {
        context.commit(‘change_sex‘,payload)
      },3000)
    }
  }
})

理解:

  state 是状态(数据中心)。

  mutations 里面定义的函数用来修改state,mutation只能执行同步操作。

  actions 的目的也是更改state,但是他不像mutation一样可以直接更改state,而是通过调用mutation来更改state。还有一个不同点是,action可以执行异步操作,比如网络请求。

  getters 返回组装DIY后的数据,比如state有个sex=“女”,通过getter在后面加一个 生 ,返回 女生,但是我觉得把组件中 computed 干的事情放到store层不是一个好主意,所以本例中不涉及。

用法:

  mutation的一个参数是 state,第二个参数是从 组件传过来的参数对象,

  action的第一个参数是一个与 store 实例具有相同方法和属性的 context 对象,这句话有点难以理解,你就把context想象成一个新的store对象,

  第二个参数还是 组件传过来的参数对象

在编辑一下 App.vue 文件

<template>
  <div id="app">
    <button @click="change_name">change name by mutation</button>
    <p>current name({{ user.name }})</p>
    <button @click="change_sex">change sex by action</button>
    <p>current sex({{ user.sex }})</p>
  </div>
</template>
<script>
export default {
  data () {
    return {
      // user: this.$store.state.user
    }
  },
  computed: {
    user() {
      return this.$store.state.user
    }
  },
  methods: {
    change_name() {
      this.$store.commit({
        type: ‘change_name‘,
        new_name: ‘李四‘
      })
    },
    change_sex() {
      this.$store.dispatch({
        type: ‘change_sex_by_action‘,
        new_sex: ‘女‘
      })
    }
  }
}
</script>

通过store获取数据都要放到computed里面,虽然在其他地方也可以直接获取,但是无法监听数据变动(就像上面注释的一样)。

change_name是通过mutation方式同步更改store中的数据,change_sex采用了action方式异步更改store中的数据。

如果在computed中需要获取的数据很多,可以使用 官方提供的 mapState,具体用法查看官方 文档 。

我自己的理解:

不要滥用store,不要把所有的数据都放到store中,在组件化开发思想下,我认为组件和组件之间本就应该独立封装,

如果一个数据只有在某个组件中使用,而不需要被其他组件共享,那么最好不要放到其中,store只存储有必要的数据,不要让他变得太臃肿,否则麻烦迟早会来。

官方文档中说明,如果store太大可以采用模块方式分割,但貌似不太优雅,

最后我还是推荐store只放必要的东西,不要让他变得太肥胖。

原文地址:https://www.cnblogs.com/codeAB/p/10251669.html

时间: 2024-08-30 02:45:34

Vue中的状态管理器 - Vuex的相关文章

Vuex内容解析和vue cli项目中使用状态管理模式Vuex

中文文档:vuex官方中文网站 一.vuex里面都有些什么内容? const store = new Vuex.Store({ state: { name: 'weish', age: 22 }, getters: { personInfo(state) { return `My name is ${state.name}, I am ${state.age}`; } } mutations: { SET_AGE(state, age) { commit(age, age); } }, acti

vue.js的状态管理vuex中store的使用

一.状态管理(vuex)简介 vuex是专为vue.js应用程序开发的状态管理模式.它采用集中存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化.vuex也集成刀vue的官方调试工具devtools extension,提供了诸如零配置的time-travel调试.状态快照导入导出等高级调试功能. 二.状态管理核心 状态管理有5个核心,分别是state.getter.mutation.action以及module.分别简单的介绍一下它们: 1.state state为

4-Vue中的状态管理模式

安装 npm install vuex --save 在自定义文件夹中的index.js中书写内容 import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) export default new Vuex.Store({ state: { user: { } }, mutations: { login (state,user) { state.user=user; } } }) 如 将其注入到vue中 存入 取出 computed: 

状态管理器 redux

简单修改state:let state = { count: 1 } 我们来使用下状态 console.log(state.count); 我们来修改下状态 state.count = 2; console.log(state.count); 实现了状态(计数)的修改和使用了. 上面的有一个很明显的问题:修改 count 之后,使用 count 的地方不能收到通知.我们可以使用发布-订阅模式来解决这个问题. /*------count 的发布订阅者实践------*/第一个版本: let sta

flutter中的状态管理Provider

今天简单说一下flutter中的状态管理,我们这次使用provider: ps:先说一个概念,Model,模型,这里面定义了我们准备全局使用的数据,或者方法: 举个栗子:我们有一个User类,用来储存用户的信息,比如登录之后,我们会拿到用户的一些个人数据,那么这些数据就可以作为属性写在Model里,同时我们在User内部,还会提供一个upUser方法,用来更新用户信息,那么这个方法也可以写在Model中,OK,以上就是我们准备的User Model; 下面是正题,go,go,go 一.Provi

理解Vue的状态管理模式Vuex

Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式.它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化. 状态管理模式.集中式存储管理,一听就很高大上,蛮吓人的.在我看来 vuex 就是把需要共享的变量全部存储在一个对象里面,然后将这个对象放在顶层组件中供其他组件使用.这么说吧,将vue想作是一个js文件.组件是函数,那么vuex就是一个全局变量,只是这个"全局变量"包含了一些特定的规则而已. 在vue的组件化开发中,经常会遇到需要将

Vue状态管理之Vuex

Vuex是专为Vue.js设计的状态管理模式.采用集中存储组件状态它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化. 1.首先让我们从一个vue的计数应用开始 new Vue({ // state data () { return { count: 0 } }, // view template: ` <div>{{ count }}</div> `, // actions methods: { increment () { this.co

vue状态管理(vuex)

vuex,官方定义为状态管理,其实这个状态管理,和H5本地缓存的作用很相似,通俗的讲,就是存储一些公用的东西,提供给各个组件使用,和服务器端的session功能也很类似. 不同的是,vuex在刷新页面的时候,会自动还原到初始的状态,话不多说,我们直接上干货: 1.安装vuex:npm install vuex --save 2.需要在man.js中引用如下代码 import Vue from 'vue' import App from './App' import router from './

Altium原理图中利用封装管理器批量修改元器件封装

批量修改封装,或者别人拿来原理图让我们画板时,发现封装全不对.如果原理图中同样封装的器件很多时,那么批量修改封装将大大减少你的工作量.下面将我批量修改封装的方法共享给大家. 在原理图界面,打开封装管理器:快捷键T-G,如图,在Design Item ID下选择需要修改的元器件ID,这个ID在设计原理图就确定了,不可以随便改变.如果全局修改本类别的元器件选择这个选项.也可以根据需求选择其他选项.如图,选中需要更改的PC814,并全选. 在图的右下角有Add添加按钮,添加封装,如图: 这时在窗口可以