vuex官网介绍

Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。Vuex 也集成到 Vue 的官方调试工具 devtools extension,提供了诸如零配置的 time-travel 调试、状态快照导入导出等高级调试功能。

vuex通俗理解

vuex就像一个无形的仓库,公共的状态我们会抽离出来放进里面。

vuex的核心主要包括以下几个部分

state:存放的我们上面所提到的状态

mutations:存放如何更改状态

getters:从state中派生出状态,比如将state中的某个状态进行过滤然后获取新的状态

actions:是mutation的加强版,它可以通过commit mutations中的方法来改变状态,最重要的是它可以进行异步操作。

modules:当用这个容器来装这些状态还是显得混乱的时候,我们就可以把容器分成几块,把状态和管理规则分类来装。这和我们创建js模块是一个目的,让代码结构更清晰。

下面我们使用vuex来做一个小功能

安装vuex

cnpm install vuex --save-dev

那么如何使用呢?

我们以一个vue项目来说明下

卖座电影

首先我们需要在type.js中定义mutations事件类型,比如改变左侧侧边栏的状态。type.js如下

export const CHANGE_LEFTNAV_STATUS = 'CHANGE_LEFTNAV_STATUS

我们的sidebar.vue组件刚开始是看不到的,只有点击头部菜单的按钮才会出现,所以一开始这个侧边组件会有一个初始状态,我们可以这样去写

<div class="sidebar-container" @click='hideNav' v-show="show">

然后我们在计算属性中这样写

show:function(){
return this.$store.getters.leftNavState
}

由于我们在vue实例中注入了vuex 所以我们可以通过this.$store来访问需要的仓库,我们在com.js中这样写

import * as types from '../types'
/**
* App通用配置
*/
const state = { leftNavState:false
} const actions = { //左侧导航栏的开关
changeLeftNavState({commit},status){
commit(types.CHANGE_LEFTNAV_STATUS,status)
}
}
const getters = { leftNavState: state => state.leftNavState
}
const mutations = {
[types.CHANGE_LEFTNAV_STATUS](state,status){
state.leftNavState = status
}
} export default {
state,
actions,
getters,
mutations
}

当访问this.$store.getters.leftNavState我们会得到它的值state=>state.leftNavState相当于传入state参数,返回state.leftNavState的值,由于我们在state中声明了leftNavState:false所以this.$store.getters.leftNavState得到的值为false所以就不会看到侧边栏组件,当然当你改成true的时候就会看到了。

这里需要说明一个一个完整的module 需要包括四个部分state,getters actions mutations,state来存放需要操作的状态 gettes类似于计算属性,改变数据有只能通过提交到mutations方式,一种是异步的,定义在actions然后提交到mutation,通过dispach来分发,另外一种是同步的直接通过commit来触发
然后我们来实现侧边栏的点击显示

我们在head

<a class="go-menu" @click="showNav"><i class="icon iconfont icon-menu"></i></a>

然后在methods中这样写

showNav: function () {
return this.$store.dispatch('changeLeftNavState', true)
}

正如上面所说异步的点击事件定义在actions中通过dispach分发,所以this.$store.dispatch会唤醒定义在actions中的方法

 changeLeftNavState({commit},status){
commit(types.CHANGE_LEFTNAV_STATUS,status)
}
//actions中的事件需要提交到mutations
const mutations = {
[types.CHANGE_LEFTNAV_STATUS](state,status){
state.leftNavState = status
}

这样仓库中的state.leftNavState的值就变成了你传入的值true。从而我们就看到了侧边栏组件
同样道理我们如果要点击隐藏这个组件那么就在sidebar.vue中这样写

<div class="sidebar-container" @click='hideNav' v-show="show">

然后我们在methods中这样写

methods:{
hideNav(){
this.$store.dispatch('changeLeftNavState',false)
}
}

这样我们就利用vuex完成了一个点击事件类型.

具体vuex到底是如何使用的,还是需要大家自己去看文档摸索的。任何项目都可以看做一个公式在我看来,我们不需要死机公式,我们要理解这个公式,这个公式就像一条线,能让我们一提起来vue就知道如何快速构建和实现一个vue项目,可以试着自己总结下。

Vue(三):vuex是什么的更多相关文章

  1. Vue 2.0 + Vue Router + Vuex

    用 Vue.js 2.x 与相配套的 Vue Router.Vuex 搭建了一个最基本的后台管理系统的骨架. 当然先要安装 node.js(包括了 npm).vue-cli 项目结构如图所示: ass ...

  2. Vue之Vuex

    一.什么是vuex Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式.它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化.简单来说就是一个数据统一 ...

  3. requirejs、vue、vuex、vue-route的结合使用,您认为可行吗?

    在五一节之前和一网友讨论前端技术时,对方提到vue.vue-route如果配合requirejs应用.当时的我没有想得很明白,也没能这位网友一个准确的回复,但我许诺于他五一研究后给他一个回复.本是一天 ...

  4. Vue中Vuex的详解与使用(简洁易懂的入门小实例)

    怎么安装 Vuex 我就不介绍了,官网上有 就是 npm install xxx 之类的.(其实就是懒~~~哈哈) 那么现在就开始正文部分了 众所周知 Vuex 是什么呢?是用来干嘛的呢? Vuex ...

  5. vue:vuex中mapState、mapGetters、mapActions辅助函数及Module的使用

    一.普通store中使用mapState.mapGetters辅助函数: 在src目录下建立store文件夹: ​ index.js如下: import Vue from 'vue'; import ...

  6. 15.vue动画& vuex

    Vue.config.productionTip = false; ==是否显示提示信息== ==import/export== export xxx 必须跟跟对象或者和定义一起 对象: export ...

  7. 深入浅出的webpack4构建工具--webpack4+vue+route+vuex项目构建(十七)

    阅读目录 一:vue传值方式有哪些? 二:理解使用Vuex 三:webpack4+vue+route+vuex 项目架构 回到顶部 一:vue传值方式有哪些? 在vue项目开发过程中,经常会使用组件来 ...

  8. vue:vuex详解

    一.什么是Vuex? https://vuex.vuejs.org/zh-cn 官方说法:Vuex 是一个专为 Vue.js应用程序开发的状态管理模式.它采用集中式存储管理应用的所有组件的状态,并以相 ...

  9. 一步一步教你用 Vue.js + Vuex 制作专门收藏微信公众号的 app

    一步一步教你用 Vue.js + Vuex 制作专门收藏微信公众号的 app 转载 作者:jrainlau 链接:https://segmentfault.com/a/1190000005844155 ...

  10. webpack4 + vue + vue-router + vuex

    ps: 所有案例使用的 node 及 npm 版本如下 node版本: v8.4.0 npm: 5.3.0 下一个案例默认是接着上一个继续写的 建议先熟悉以下文档 vue vue-router vue ...

随机推荐

  1. 发现一个ReactNative大神

    传送门: RN使用技巧:http://www.jianshu.com/p/2f575cc35780 RN 进阶技巧:http://www.jianshu.com/p/b877115fff1b 亮点有: ...

  2. OpenCV实现任意大小图片的合并(转)

    OpenCV实现图像合并主要有两种方法 方法一:使用Mat.push_back方法将列数相同的图像加到最后一行 方法二: 主要思路是将图像拷贝到待合并图像的感兴趣区域 (1)新建一个要合并的图像(容器 ...

  3. 对2个hex(16进制)字符串进行异或操作

    private static String hexXOR(String hex1, String hex2){ BigInteger i1 = new BigInteger(hex1, 16); Bi ...

  4. Linux主流架构运维工作简单剖析

    转载:http://wgkgood.blog.51cto.com/1192594/1586259 随着IT运维的不断发展,尤其的Linux的飞速发展,越来越多的企业开始使用Linux操作系统平台,例如 ...

  5. group by 分组

    group by 分组:一般情况下group需与统计函数(聚合函数)一起使用才有意义 mysql中的五种统计函数: ()max:求最大值 select max(goods_price) from go ...

  6. VBA 一个很神奇的东西

    百度经验参考:http://jingyan.baidu.com/article/4ae03de32663953efe9e6b47.html 今天奇迹般的发现了VBA,都怪自己平时使用excle不够多, ...

  7. topshelf 开发windows 服务资料

    官方配置 http://docs.topshelf-project.com/en/latest/configuration/config_api.html#service-start-modes to ...

  8. Linux指令范例速查手册

    linux命令繁多,命令就是AK的子弹,对上口径,百发百中! 无意发现一本介绍Linux命令的手册--->[Linux指令范例速查手册] 下载: https://pan.baidu.com/s/ ...

  9. Linux常见命令缩写

    缩写,是简介高效地表达 unix   unix-like   Linux 00.命令简写 ls:list(列出目录内容)cd:Change Directory(改变目录)su:switch user ...

  10. Jqeury Mobile实战之切屏效果以及屏幕滚动到底端加载更多和点击切换更多

    http://blog.csdn.net/q718330882/article/details/46120691 //页面滚动到底部加载更多事件 $( window ).scroll(function ...