相比接触vue的同学们已经看了官方文档了。这里我用一个简单的demo来阐述下vuex的知识点,虽然简单,但是容易理解。也加深自己的记忆。

用脚手架建立个项目vue init webpakc-simple ,安装下vuex,这里我新建2个组件productOne,productTwo.
好,如果想在2个组件中引用同一组数据,笨方法就是在每个组件的data里写上数据,聪明点可以在根组件中建立数据,通过props传给子组件。那么这里,我用vuex来储存数据。通过在根实例中注册 store 选项,该 store 实例会注入到根组件下的所有子组件中,且子组件能通过 this.$store 访问到。

新建个store文件夹,里面新建个store.js。这里就是vuex状态管理作用的地方。
store.js中

import Vue from 'vue'
import Vuex from 'vuex' Vue.use(Vuex) export const store = new Vuex.Store({
state: {
}
})

main.js中,引入store模块并注册。

import Vue from 'vue'
import App from './App.vue'
import {store} from './store/store.js'
new Vue({
el: '#app',
store,
render: h => h(App)
})

state

官网上说,state是作为一个单一状态树,用一个对象来包含了全部的应用层级状态。至此它便作为一个唯一数据源的存在。这也意味着,每个应用将仅仅包含一个 store 实例。单一状态树让我们能够直接地定位任一特定的状态片段,在调试的过程中也能轻易地取得整个当前应用状态的快照。

由于vuex的状态存储是响应式的,那么在组件中,我们就可以用计算属性来获取state状态。每当 store.state.count 变化的时候, 都会重新求取计算属性,并且触发更新相关联的 DOM。

import Vue from 'vue'
import Vuex from 'vuex' Vue.use(Vuex) export const store = new Vuex.Store({
state: {
products:[
{name:'apple', price: '2'},
{name:'banana', price: '3'},
{name:'pear', price: '4'},
{name:'melon', price: '5'},
]
}
})

两个组件中的结构大概如下:用计算属性用this.$state来返回这个状态。

<template>
<div class="product-one">
<h2>product-one</h2>
<ul>
<li v-for="item in product">
<div class="name">{{item.name}}</div>
<div class="price">{{item.price}}</div>
</li>
</ul>
</div>
</template>
<script>
export default {
computed: {
product() {
return this.$store.state.products
}
}
}
</script>

这样2个组件中的数据就可以统一在store.js中管理了。效果如下:

 
 
 

好,如果现在想改变下数据的一些内容,比如价格都涨2倍,那该怎么做呢,此时就用到getters

getter

官网上说,getters就相当于是store的计算属性,可以处理state的数据,它接受第一个参数就是state。那么接下来就简单了,把计算逻辑写在getters里,在组件中再获取getters就行了。

import Vue from 'vue'
import Vuex from 'vuex' Vue.use(Vuex) export const store = new Vuex.Store({
state: {
products:[
{name:'apple', price: '2'},
{name:'banana', price: '3'},
{name:'pear', price: '4'},
{name:'melon', price: '5'},
]
}, getters: {
changeProduct: (state) => {
return state.products.map(val => {
return {
name: '**' + val.name + '--',
price: val.price*2
}
})
return state.products
}
}
})

在子组件中,用计算属性来获取getters,并在DOM中遍历这个计算属性。

    export default {
computed: {
product() {
return this.$store.state.products
},
changeProduct(){
return this.$store.getters.changeProduct
}
}
}
<li v-for="item in changeProduct">
<div class="name">{{item.name}}</div>
<div class="price">{{item.price}}</div>
</li>

可以看到,2个组件的数据都改变了。

 
 
 

mutation

更改 Vuex 的 store 中的状态的唯一方法是提交 mutation。Vuex 中的 mutation 非常类似于事件:每个 mutation 都有一个字符串的 事件类型 (type) 和 一个 回调函数 (handler)。这个回调函数就是我们实际进行状态更改的地方,并且它会接受 state 作为第一个参数
你不能直接调用一个 mutation handler。这个选项更像是事件注册:“当触发一个类型为 increment 的 mutation 时,调用此函数。”要唤醒一个 mutation handler,你需要以相应的 type 调用 store.commit 方法。
简单来说,就是mutations就类似事件,子组件中用this.$store.commit('事件名')来获取。

import Vue from 'vue'
import Vuex from 'vuex' Vue.use(Vuex) export const store = new Vuex.Store({
state: {
products:[
{name:'apple', price: '2'},
{name:'banana', price: '3'},
{name:'pear', price: '4'},
{name:'melon', price: '5'},
]
}, getters: {
changeProduct(state){
return state.products.map(val => {
return {
name: '**' + val.name + '--',
price: val.price*2
}
})
return state.products
}
}, mutations: {
decrePrice(state){
state.products.forEach(val => {
val.price -= 1
})
}
}
})

子组件中

methods: {
decrePrice(){
return this.$store.commit('decrePrice')
}
}

action

action和mutation类似,不同的是,Action 提交的是 mutation,而不是直接变更状态。而且Action支持异步。mutation必须同步执行
Action 函数接受一个与 store 实例具有相同方法和属性的 context 对象,因此你可以调用 context.commit 提交一个 mutation,或者通过 context.state 和 context.getters 来获取 state 和 getters。

import Vue from 'vue'
import Vuex from 'vuex' Vue.use(Vuex) export const store = new Vuex.Store({
state: {
products:[
{name:'apple', price: '2'},
{name:'banana', price: '3'},
{name:'pear', price: '4'},
{name:'melon', price: '5'},
]
}, getters: {
changeProduct(state){
return state.products.map(val => {
return {
name: '**' + val.name + '--',
price: val.price*2
}
})
return state.products
}
}, mutations: {
decrePrice(state){
state.products.forEach(val => {
val.price -= 1
})
}
}, actions: {
decrePriceAction(context){
setTimeout(()=>{
context.commit('decrePrice')
}, 2000)
}
}
})

子组件中,用this.$store.dispatch('action的名字')来获取。

        methods: {
decrePrice(){
// return this.$store.commit('decrePrice')
return this.$store.dispatch('decrePriceAction')
}
}

好,一些基本的就这样,其它的可以去官网看哦~

作者:从小就很瘦
链接:https://www.jianshu.com/p/5e6de947d088
来源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

一个demo 理解 vuex的更多相关文章

  1. 理解vuex的状态管理模式架构

    理解vuex的状态管理模式架构 一: 什么是vuex?官方解释如下:vuex是一个专为vue.js应用程序开发的状态管理模式.它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证以一种可预测的 ...

  2. 理解Vuex的辅助函数mapState, mapActions, mapMutations用法

    在讲解这些属性之前,假如我们项目的目录的结构如下: ### 目录结构如下: demo1 # 工程名 | |--- dist # 打包后生成的目录文件 | |--- node_modules # 所有的 ...

  3. [转]理解Vuex的辅助函数mapState, mapActions, mapMutations用法

    原文地址:https://www.cnblogs.com/tugenhua0707/p/9794423.html 在讲解这些属性之前,假如我们项目的目录的结构如下: ### 目录结构如下: demo1 ...

  4. VueJs(14)---理解Vuex

    理解Vuex 一.Vuex 是什么? 首先我们来分析一种实际开发中用vue.js的场景,你有n个组件,当你改变一个组件数据的时候需要同时改变其它n个组件的数据,那么我想你可能会对 vue 组件之间的通 ...

  5. .NET Core微服务之路:让我们对上一个Demo通讯进行修改,完成RPC通讯

    最近一段时间有些事情耽搁了更新,抱歉各位了. 上一篇我们简单的介绍了DotNetty通信框架,并简单的介绍了基于DotNetty实现了回路(Echo)通信过程. 我们来回忆一下上一个项目的整个流程: ...

  6. (1)shiro简介和第一个demo

    之前一直在用shiro开发,不过只是会使用,并没有深入了解,最近有时间学习了一下,把最近学习所得分享一下. shiro简介 Apache Shiro是一个强大且易用的Java安全框架,执行身份验证.授 ...

  7. webpack快速入门——webpack3.X 快速上手一个Demo

    1.进入根目录,建两个文件夹,分别为src和dist 1).src文件夹:用来存放我们编写的javascript代码,可以简单的理解为用JavaScript编写的模块. 2).dist文件夹:用来存放 ...

  8. Angular2 不明真相第一个Demo例子

    如果不是去年换工作接触到AngularJS,估计是不会花时间去学习这个框架的,毕竟是前端的框架,不是自己熟悉的领域.但是为了混得下去,去年就学习了AngularJS的一些用法,当时还整理了一些积累 & ...

  9. 分享知识-快乐自己:初始 Struts2 (基本概念)及 搭建第一个Demo

    1):struts2 的基本概念: 1-1):Struts2 是什么? 1.Struts2是一个基于MVC设计模式的Web应用框架,它本质上相当于一个servlet,在MVC设计模式中,Struts2 ...

随机推荐

  1. 传入一个integer数组,取出最大、最小值

    /** * <p> * 传入一个integer数组,取出最大值 * </p> * @author yunns 2015年11月19日 * @param array * @ret ...

  2. linux系统分析工具之Blktrace

    Blktrace简介: blktrace是一个针对Linux内核中块设备I/O层的跟踪工具,用来收集磁盘IO信息中当IO进行到块设备层(block层,所以叫blk trace)时的详细信息(如IO请求 ...

  3. oracle 子查询 where having from ,from子查询提高效率

    where 子查询主要功能是控制数据行的,返回结果一般都是单行单列.多行单列.单行多列数据 单行单列 SELECT * FROM emp WHERE hiredate=( SELECT MIN(hir ...

  4. 关于安装时无法重启rabbitmq服务

    如图重启时找不到rabbitmq, 解决办法: rabbitmqctl stop :停止rabbitmq  rabbitmq-server restart : 重启rabbitmq 这两步就可以完成重 ...

  5. hisi3559的usb无线网卡驱动(rtl8192cu)(一条龙服务:内核编译、驱动编译、iw等工具编译)

    usb无线网卡驱动(rtl8192cu) 内核编译.驱动编译.iw等工具编译  (哈哈,如果有其他问题,麻烦留言:) 环境 板卡:hi3559av100(arm64) 交叉编译链:aarch64-hi ...

  6. springboot快速入门(四)——数据库操作

    一.Spring-Data-Jpa的引入 先给出官方文档:https://docs.spring.io/spring-data/jpa/docs/current/reference/html/ IBM ...

  7. vba 批量生成条形图代码

    Sub hong3()'' 宏3 宏d Dim a, b As Integer Dim str As String For a = 227 To 947 Step 15 b = a + 5 str = ...

  8. JavaScript总结(三)

    如何执行代码语句? 使用函数,函数是一组可以随时随地运行的语句,它们是JavaScript的核心.函数是由关键字function.函数名加一组参数以及置于括号中要执行的代码声明的.语法如下: Func ...

  9. 【HNOI2015】菜肴制作

    题面 题解 这道题目首先可以想到拓扑排序,但是肯定不是字典序最小的排列. 比如说,有\(4\)种菜,限制为\(2 \to 4, 3 \to 1\),那么如果求字典序最小的排列会算出\((2, 3, 1 ...

  10. Linux下通过进程名查询占用的端口

    1.首先根据名称用ps命令查看进程ID: ps -ef | grep zookeeper jim 10997 1959 0 12月14 pts/2 00:00:01 /usr/lib/jvm/java ...