通过一个简单实例了解vuex

九路 等级 784 1 0
标签: vuexhttps前端

简单说明

什么是vuex,vuex怎么使用,什么场景下适合使用vuex, vuex 文档中都有介绍。看完文档之后,都知道vuex的核心有State、Getter、Mutation、Action、Module,也都知道分别都是干嘛的。但是实际到项目中可能就会出现不知道怎么动手实际操作了。下面就通过一个简单实例来说下vuex具体如何使用。

分步操作,从安装到实例操作。

安装vuex

安装vuex有3种方式。其中两种是在通过 vue create project-name创建项目时选择安装,如图所示:

通过一个简单实例了解vuex

vuex-one-1.png

第一种会把vue-router、vuex、babel、eslint一起安装。

第二种手动选择安装,根据需要选择性安装,如图所示:

通过一个简单实例了解vuex

vuex-one-2.png

第三种就是在创建项目时选择default,只会安装babel、eslint。创建好项目之后,进入到项目,然后安装vuex。

> cd project-name
> npm install vuex 

分步准备阶段

按步骤,一步步来

项目目录:

通过一个简单实例了解vuex

vuex-one-3.png

由于使用单一状态树,应用的所有状态会集中到一个比较大的对象。当应用变得非常复杂时,store 对象就有可能变得相当臃肿。为了解决以上问题,Vuex 允许我们将 store 分割成模块(module)。每个模块拥有自己的 state、mutation、action、getter。
而实际项目也会分多个模块,比如:用户、订单等。此实例中只创建了一个用户模块。

模块文件

  1. 在src目录下创建一个store目录,进入到store目录,然后在创建一个modules目录,最后user模块文件user.js
const state = {
    //在此处定义组件要用到的属性值
  status: false,
  todoList: []
}

const mutations = {
/**
* 此处定义修改状态值的函数,注意只能是同步函数。
* 因为如果是异步函数,当 mutation 触发的时候,回调函数还没有被调用,
* 那么在回调函数中进行的状态的改变就不可追踪了。
*/
  SET_STATUS: (state, status) => {
    state.status = status
  },
  SET_TODOLIST: (state, todos) => {
    state.todoList = todos
  }
}

const actions = {
    /**
    * Action 类似于 mutation,不同在于:
    * ① Action 提交的是 mutation,而不是直接变更状态。
    * ② Action 可以包含任意异步操作。
    * 最后一个 store.dispatch 在不同模块中可以触发多个 action 函数了。
    */
  login ({ commit }, val) {
    const { status } = val
    return new Promise((resolve, reject) => {
      setTimeout(() => {
        commit('SET_STATUS', status)
        resolve({ status: status })
      }, 100)
    })
  },
  todoList ({ commit }) {
    return new Promise((resolve) => {
      setTimeout(() => {
        commit('SET_TODOLIST', todo)
        resolve({ code: 200 })
      }, 100)
    })
  }
}

export default {
  namespaced: true,
  state,
  mutations,
  actions
} 

总的来说:①state中定义好要用的属性值;②mutation中定义好操作这些属性的函数(同步函数);③action中定义可以提交mutation的函数,可以是异步函数;

getters.js

在store目录下创建getters文件

如果modules有多个模块,那么可以在getters文件中统一的提供供组件中获取不同模块中的属性值。如代码所示:

const getters = {
    //user.js
  status: state => state.user.status,
  doneTodos: state => {
    return state.user.todoList.filter(todo => todo.done)
  }
    //order.js
    payStatus: state => state.order.payStatus
}

export default getters 

index.js

在store目录下创建index文件

导入之前在modules定义的文件和getters文件。导入modules有2种方式:①按照注释的方式导入;
②按照代码中现在方式引入使用

import Vue from 'vue'
import Vuex from 'vuex'
import getters from './getters'
# improt user from './modules/user'

Vue.use(Vuex)

const modulesFiles = require.context('./modules', true, /\.js$/)

const modules = modulesFiles.keys().reduce((modules, modulePath) => {
  const moduleName = modulePath.replace(/^\.\/(.*)\.\w+$/, '$1')
  const value = modulesFiles(modulePath)
  modules[moduleName] = value.default
  return modules
}, {})

const store = new Vuex.Store({
  //user,
    modules,
  getters
})
export default store 

最后在main.js中导入store

import Vue from 'vue'
import App from './App.vue'
import router from './router'
import store from './store'

Vue.config.productionTip = false

new Vue({
  router,
  store,
  render: h => h(App)
}).$mount('#app') 

实例演示

通过一个简单实例了解vuex

vuex-one-4.gif

实例代码

实例代码

收藏
评论区

相关推荐

vue高级进阶系列——用typescript玩转vue和vuex
       用过vue的朋友大概对vuex也不陌生,vuex的官方解释是专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。说的简单点就是对vue的状态进行统一管理,如下图介绍了其管理模式: im
通过一个简单实例了解vuex
简单说明 什么是vuex,vuex怎么使用,什么场景下适合使用vuex, vuex 文档(https://links.jianshu.com/go?tohttps%3A%2F%2Fvuex.vuejs.org%2Fzh%2F)中都有介绍。看完文档之后,都知道vuex的核心有State、Getter、Mutation、Action、Modul
Vuex 4 正式发布:打包现在与 Vue 3 一致
Vuex 是一个专门为 Vue.js 应用程序开发的状态管理模式。Vuex 采用集中式存储管理应用的所有组件组件的状态。换句话说,Vuex 就是帮开发者存储多个组件共享的数据,方便开发者对其读取的更改的工具。 Vuex 4 正式版本现已发布。 Vuex 4 的改进重点是兼容性。Vuex 4 支持 Vue 3,并提供了与 Vuex 3 完全相同的
了解Vuex状态管理模式
1 Vuex是什么呢?它是Vue的状态管理模式,在使用vue的时候,需要在vue中各个组件之间传递值是很痛苦的,在vue中我们可以使用vuex来保存我们需要管理的状态值,值一旦被改变,所有引用该值的地方就会自动更新。是不是很方便,很好用呢? vuex是专门为vue.js设计的状态管理模式,集中式存储和管理应用程序中所有组件的状态,vuex也集成了vue的
vue: 解决vuex页面刷新数据丢失问题
一、问题描述 1、一般在登录成功的时候需要把用户信息,菜单信息放置 vuex 中,作为全局的共享数据。但是在页面刷新的时候 vuex 里的数据会重新初始化,导致数据丢失。因为 vuex 里的数据是保存在运行内存中的,当页面刷新时,页面会重新加载 vue 实例,vuex 里面的数据就会被清空。 2、我在一个组件(例如登录组件页面)中登录了后,其它页面要怎
记录Vue项目实现axios请求头带上token
在vue项目中首先 npm 命令安装 axios: npm install axios Saxios 的封装使用请求带上token,token通过登录获取存在vuex,为防止刷新丢失token使用持久化 vuexpersistedstate 插件保存数据npm i S vuexpersistedstateimport persistedStat
Vue方向:Vuex状态管理:Action异步函数
1、Action的使用        Action类似于mutation,不同之处在于Action提交的是mutation,而不是直接更改状态,Action可以包含任何的异步操作。 2、定义以及使用Action代码 3、分发Action代码代码action 4、Action函数参数
veux的使用
1)说说什么是vuex(下定义)2)vuex解决了哪些问题,为什么要用(必要性)3)怎么使用vuex(使用方法)4)描述vuex原理,提升答案深度(深层原理升华答案)vuex的流程图分析:我们可以看到图中虚线框包裹起来的部分就是vuex的三个组成部分(Action,Mutations,state),我们来简单的捋一下整个流程:首先vue的组件在响应用户行为交
Vue方向:Vuex状态管理: 辅助函数mapState与mapGetters
1、mapState和mapGetters的作用      mapState用于将state中的数据映射到组件的计算属性中,而mapGetters用于将getter中的计算属性映射到组件的计算属性中,之前获取Vuex数据都是通过$store找到state对象,再去state中去拿数据,操作getter,muta
Vue开发指南:你都需要学点啥?
如果您是Vue开发的新手,您可能已经听过很多关于它的专业术语了,例如:单页面应用程序、异步组件、服务器端呈现等。 另外您可能还经常听到和Vue一起提到的工具和库,如Vuex、Webpack、Vue CLI和Nuxt。 也许您在面对这些未知的术语和
Vue3现状报告及未来规划
近况158 万周活跃用户(通过 devtools 插件来统计),940 万的月下载量。对比去年Devtools:110 万 158 万(+43.6%) NPM:620 万 940 万(+51.6%)Vue 3.0 One Piece自那之后,Vue3 逐渐趋于稳定,继续探索用户体验。Vue Router 4.0已经稳定。Vuex 4.0已经稳定。生态慢慢
TypeScript 4.1 新特性:字符串模板类型,Vuex 终于有救了?
TypeScript 4.1 快要发布了,老爷子 Anders Hejlsberg\[1\] 加入了一项重大更新,**「字符串模板类型」** 的支持。昨天看到这个更新的我特别兴奋,曾几何时,只要一遇到字符串拼接相关的类型,TypeScript 就束手无策了,比如: * `Vuex` 中加了 `namespace` 以后,`dispatch` 一个 `m
Vue CLI 3搭建vue+vuex 最全分析
一、介绍 ==== Vue CLI 是一个基于 Vue.js 进行快速开发的完整系统。有三个组件: **CLI**:`@vue/cli` 全局安装的 npm 包,提供了终端里的vue命令(如:vue create 、vue serve 、vue ui 等命令) **CLI 服务**:`@vue/cli-service`是一个开发环境依赖。构建于 [we
Vue 兼容 ie9 的全面解决方案
前言 -- **背景情况** * vue - 2.5.11 * vue-cli 使用模板 `webpack-simple` * http请求:axios Vue 官方对于 ie 浏览器版本兼容情况的描述是 ie9+,即是 ie9 及更高的版本。经过测试,Vue 的核心框架 `vuejs` 本身,以及生态的官方核心插件(VueRouter、V
vue+electron 环境搭建记录(基于vue-cli-plugin-electron-builder)
目标 搭建vue + electron的工程 主要步骤 构建初始化工程 创建vue3 工程使用vuecli 工具创建一个vue3工程vue ui使用网页创建,注意vue版本选3.0,构建工具选择yarn::: tip 选择yarn工具:::::: tip 手动选择依赖:::::: tip 开启vuex vuerouter eslint less 等功能