前端培训-中级阶段(41)- vue2.x 状态管理Vuex

简介: 前端最基础的就是 HTML+CSS+Javascript。掌握了这三门技术就算入门,但也仅仅是入门,现在前端开发的定义已经远远不止这些。前端小课堂(HTML/CSS/JS),本着提升技术水平,打牢基础知识的中心思想,我们开课啦(每周四)。Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。

五大核心模块



  • State,数据中心,可以理解为 Vue 中的 data。只不过为了保持数据流向,需要用store.commit('increment')来修改(Mutation 内部再去修改 state),可以更明确地追踪到状态的变化。


  • 获取时可以使用 store.state.countthis.$store.state.countmapState


  • mapState 可以接收对象和数组,可以直接放在computed: mapState({})上,也可以使用展开运算符computed: {localComputed () {},


  • ...mapState({})}
  • 对象形式


mapState({
    // 箭头函数可使代码更简练
    count: state => state.count,
    // 传字符串参数 'count' 等同于 `state => state.count`
    countAlias: 'count',
    // 为了能够使用 `this` 获取局部状态,必须使用常规函数
    countPlusLocalState (state) {
      return state.count + this.localCount
    }
  })


  • 数组形式


mapState([
  // 映射 this.count 为 store.state.count
  'count'
])


  • Getter,可以理解为 Vue 的 computed 计算属性,返回值也会根据它的依赖被缓存起来,只有当它的依赖值发生了改变才会被重新计算。


  • 获取时可以使用 store.getters.countthis.$store.getters.countmapState


  • mapGetters
  • 单纯的映射 ...mapGetters(['doneTodosCount','anotherGetter',])
  • 换个名字映射出来 ...mapGetters({doneCount: 'doneTodosCount'})


  • Mutation可以理解为methods ,也可以理解为 setState ,只不过mutation 必须是同步函数,定义上来说是用来同步修改 state。


  • store.commit('increment') 不传递内容 increment (state, payload){payload == undefined}


  • store.commit('increment', 1) 传递数值 increment (state, payload){payload == 1}


  • store.commit('increment', {n:1}) 传递对象(推荐) increment (state, payload){payload == {n:1}}(我只是在描述内容是什么,想测试可以用 console.log)


  • ...mapMutations(['increment'])


  • ...mapMutations({add:'increment'})


this.add() 映射为 this.$store.commit('increment')


  • Action Action 提交的是 mutation,而不是直接变更状态。Action 可以包含任意异步操作。


在 vue 中使用 mapActions 做快捷映射,也可以不做映射直接使用 store.dispatch('increment')


dispatch 会返回一个 Promise ,所以我们也可以愉快的监听异步是否执行完成。


  • Module Vuex 允许我们将 store 分割成模块(module)。每个模块拥有自己的 state、mutation、action、getter、甚至是嵌套子模块——从上至下进行同样方式的分割:


const moduleA = {
  namespaced: true,//通过namespaced开启命名空间,默认情况下,模块内部的 action、mutation 和 getter 是注册在**全局命名空间**的——这样使得多个模块能够对同一 mutation 或 action 作出响应。
state: () => ({ ... }),
  mutations: { ... },
  actions: { ... },
  getters: { ... }
}
const moduleB = {
  state: () => ({ ... }),
  mutations: { ... },
  actions: { ... }
}
const store = new Vuex.Store({
  modules: {
    a: moduleA,
    b: moduleB
  }
})
store.state.a // -> moduleA 的状态
store.state.b // -> moduleB 的状态


相关文章
|
16天前
|
存储 JavaScript 前端开发
前端技术分享:使用Vue.js与Vuex管理状态
【10月更文挑战第1天】前端技术分享:使用Vue.js与Vuex管理状态
38 6
|
27天前
|
存储 JavaScript 前端开发
前端 vue:路由的高级使用
前端 vue:路由的高级使用
|
4天前
|
前端开发 JavaScript 安全
在vue前端开发中基于refreshToken和axios拦截器实现token的无感刷新
在vue前端开发中基于refreshToken和axios拦截器实现token的无感刷新
28 4
|
6天前
|
存储 缓存 前端开发
Vuex深入探究:前端状态管理的利器
【10月更文挑战第11天】Vuex深入探究:前端状态管理的利器
16 1
|
10天前
|
JavaScript 前端开发 Python
django接收前端vue传输的formData图片数据
django接收前端vue传输的formData图片数据
16 4
|
9天前
|
JavaScript 前端开发 Java
VUE学习四:前端模块化,ES6和ES5如何实现模块化
这篇文章介绍了前端模块化的概念,以及如何在ES6和ES5中实现模块化,包括ES6模块化的基本用法、默认导出与混合导出、重命名export和import,以及ES6之前如何通过函数闭包和CommonJS规范实现模块化。
28 0
VUE学习四:前端模块化,ES6和ES5如何实现模块化
|
19天前
|
JavaScript 前端开发 网络架构
|
18天前
|
前端开发 JavaScript 应用服务中间件
linux安装nginx和前端部署vue项目(实际测试react项目也可以)
本文是一篇详细的教程,介绍了如何在Linux系统上安装和配置nginx,以及如何将打包好的前端项目(如Vue或React)上传和部署到服务器上,包括了常见的错误处理方法。
36 0
linux安装nginx和前端部署vue项目(实际测试react项目也可以)
|
5天前
|
JSON 前端开发 JavaScript
Vue微前端新探:iframe优雅升级,扬长避短,重获新生
Vue微前端新探:iframe优雅升级,扬长避短,重获新生
27 0
|
5天前
|
JavaScript 前端开发 应用服务中间件
vue前端开发中,通过vue.config.js配置和nginx配置,实现多个入口文件的实现方法
vue前端开发中,通过vue.config.js配置和nginx配置,实现多个入口文件的实现方法
35 0