Vue | 『vue-vuex 精讲』

简介: 解决什么问题?vuex解决了状态管理问题,通过集中管理状态,使得state、action和view实现松耦合,从而让代码更易维护

image.png

image.png

〖一:VueX基本概念〗

解决什么问题?vuex解决了状态管理问题,通过集中管理状态,使得state、action和view实现松耦合,从而让代码更易维护

〖二:vuex的基本使用方法〗

1.安装vuex依赖


npm i -S vuex

2.使用vuex插件


import Store from 'vuex'

Vue.use(Store)

3.初始化vuex对象


const store = new Vuex.Store({
  state: {
    data: 'this is data'
  },
  mutations: {
    SET_DATA(state, data) {
      state.data = data
    }
  },
  actions: {
    setData({ commit }, data) {
      commit('SET_DATA', data)
    }
  }
})

4.实例化Vue对象,传入store参数


new Vue({
  render: h => h(App),
  router,
  store
})

5.读取vuex状态


<div>{{$store.state.data}}</div>

6.更新vuex状态


update() {
  this.$store.dispatch('setData', 'this is update data')
}

〖三:vuex模块化〗


实际项目开发中,状态众多,如果全部混在一起,则难以分辨,而且容易相互冲突,
为了解决问题,vuex引入模块化的概念,解决这个问题,下面我们定义a和b两个模块:

const moduleA = {
  state: {
    data: 'this is a'
  },
  mutations: {
    SET_DATA(state, data) {
      state.data = data
    }
  },
  actions: {
    setData({ commit }, data) {
      commit('SET_DATA', data)
    }
  }
}
const moduleB = {
  state: {
    data: 'this is b'
  },
  mutations: {
    SET_DATA(state, data) {
      state.data = data
    }
  },
  actions: {
    setData({ commit }, data) {
      commit('SET_DATA', data)
    }
  }
}

1.修改store的初始化代码:


const store = new Vuex.Store({
  modules: {
    a: moduleA,
    b: moduleB
  }
})

2.修改获取状态的代码,此时需要加入模块进行区分:


<div>{{$store.state.a.data}}</div>
<div>{{$store.state.b.data}}</div>
<button @click="update('a')">update a</button>
<button @click="update('b')">update b</button>

3.修改update方法:


update(ns) {
  this.$store.dispatch(`setData`, `update ${ns}`)
}

〖四:vuex命名空间〗

上述代码在执行过程中,获取状态没有问题,但是修改状态会出现问题,
因为两个模块出现同名actions,所以此时需要使用命名空间来解决这个问题:

const moduleA = {
  namespaced: true,
  // ...
}

1.修改update方法:


update(ns) {
  this.$store.dispatch(`${ns}/setData`, `update ${ns}`)
}

image.png

相关文章
|
1天前
|
设计模式 JavaScript 前端开发
Vue源码学习需要哪些工具和技能
【4月更文挑战第20天】学习Vue源码需具备的工具与技能:VS Code或WebStorm作为代码编辑器,Node.js与npm管理依赖,Git操作仓库。基础包括JavaScript、ES6+语法、前端知识(HTML/CSS/浏览器原理)及Vue基础知识。进阶则需源码阅读理解能力,调试技巧,熟悉设计模式和架构思想。学习方法强调系统学习、实践与持续关注Vue最新动态。
16 8
|
1天前
|
JavaScript 前端开发 编译器
Vue 源码学习路线
【4月更文挑战第20天】探索Vue源码涉及响应式系统、虚拟DOM、模板编译等核心概念。先掌握Vue基础知识、JavaScript(ES6+)和前端工程化。从源码入口文件开始,研究响应式、虚拟DOM、模板编译、实例方法、全局API及生命周期。理解编译器和渲染器工作原理,实践编写Vue插件,参与开源项目,阅读相关文章教程,持续关注Vue最新动态。这是一个循序渐进、需要耐心和实践的过程。
7 1
|
1天前
|
JavaScript 前端开发
鼠标监视 | 拖拽方块 | Vue
鼠标监视 | 拖拽方块 | Vue
5 0
|
1天前
|
JavaScript
Vue控制是否禁用disabled属性
Vue控制是否禁用disabled属性
6 1
|
1天前
|
JavaScript 前端开发
Vue鼠标悬浮切换图片
Vue鼠标悬浮切换图片
5 0
|
1天前
|
JavaScript 前端开发 内存技术
Vue入门:构建你的第一个Vue应用程序
【4月更文挑战第22天】Vue.js 入门教程:安装 Node.js 和 npm,使用 Vue CLI (`npm install -g @vue/cli`) 创建项目,选择预设或自定义配置。在 `src/components/` 创建 `HelloWorld.vue` 组件,显示数据属性。在 `App.vue` 中引入并注册组件,启动开发服务器 (`npm run serve`) 预览。开始你的 Vue 之旅!
|
1天前
|
JavaScript 前端开发 UED
动画效果:给 Vue 应用添加过渡和动画
【4月更文挑战第22天】Vue 框架提供强大的过渡和动画功能,增强用户体验,创建流畅的用户界面。通过CSS动画、设置过渡属性和自定义过渡,开发者能实现多样化效果。同时,结合组件状态、关注性能并测试优化,确保在不同设备上运行良好,打造引人入胜的应用交互。
|
4天前
|
JavaScript
Ant design Vue 父子组件传递(代码案例--不懂的地方可以私信本博主)
Ant design Vue 父子组件传递(代码案例--不懂的地方可以私信本博主)
10 0
|
4天前
|
JavaScript 前端开发
ant design vue 配置菜单外部打开
ant design vue 配置菜单外部打开
12 0
|
4天前
|
JavaScript
ant design vue 在列表中使用插槽 例如当性别为0的时候在列表中我想显示男
ant design vue 在列表中使用插槽 例如当性别为0的时候在列表中我想显示男
7 0