state

大白话:获取state的值

vuex中state数据是响应式的。只要state中数据发生变化。vue组件自动更新。

要想做到响应式

前提:是在mutaion中定义函数修改state值。

  1. 最好提前在你的 store 中初始化好所有所需属性。

  2. 当需要在对象上添加新属性时,使用 Vue.set(obj, 'newProp', value)就是响应式

info: {
name: 'kebe',
age: 40,
height: 1.98
} //下面
state.info.name='old-old-kebi' //修改已有的值还是响应式
state.info.address='beijing'//增加新的属性和值。该属性不是响应式。state.info确实增加了adderss属性。但是html试图不会发生变化。
state.info['id']=100 //不是响应式
Vue.set(state.info,'sex','男') //通过vue.set()增加属性和值就是响应式的

mapState

不管用不用mapState辅助函数,vue当前实例访问store.state数据都是在 cumputed计算属性内。

注意:进入到计算属性computed的属性。vue实例可以直接使用。同data数据一样。

mapState通过扩展运算符将store.state.属性 映射this.属性 this.指代当前vue实例对象。

//store.js
state: {
count: 100,
str: 'abc',
student: [
{ name: 'zs', age: 10 },
{ name: 'lisi', age: 30 },
{ name: 'ww', age: 30 },
{ name: 'zq', age: 20 }
]
}, 没用mapState之前 **当前vue实例取store.state.属性** 数据是这样的
//computed
count(){
return this.$store.state.count
},
str(){
return this.$store.state.str
},
student(){
return this.$store.state.student
}, import { mapState, mapMutations, mapGetters } from "vuex";
//方式1数组形式。这样当前vue实例上就有了count,str,student属性。值就是对应的值。
...mapState(['count','str','student']), //方式2对象形式 不一定要同名
//不可以这样写 ...mapState({ count,str, student}),
...mapState({ count: "count", str: "str", student: "student" }), //或者 `state => state.count` 等同于 上面的'count'
...mapState({ count: state => state.count, student: "student" }),

getters

大白话:获取state的值

Vuex 允许我们在 store 中定义“getter”(可以认为是 store 的计算属性computed)。就像计算属性一样,getter 的返回值会根据它的依赖被缓存起来,且只有当它的依赖值发生了改变才会被重新计算。

getters里面函数fn形参依次是(state,getters)最多只接受两个参数。

getters: {
//getters里面的方法接收一个state参数,指向state,可直接调用state中的数据
getMore20(state){
//直接返回一个值
return state.student.filter(element=>element.age>20)
},
//getters 也可以接受其他 getter 必须是作为第二个参数:
getMore20Length(state,getters){
//直接返回一个值
return getters.getMore20.length
},
// 用户想传参就返回一个函数
getMoreAge(state) {
//返回一个函数。
return age => state.student.filter(element => element.age > age)
}, getMoreAgeLen(state,getters){
// return getters.getMoreAge.length
return age=>state.student.filter(element=>element.age>age).length
},
}

不用mapgetters

computed: {
getMore20() {
return this.$store.getters.getMore20;
},
getMore20Length() {
return this.$store.getters.getMore20Length;
},
getName() {
return this.$store.getters.getName;
},
getMoreAge() {
return this.$store.getters.getMoreAge;
},
getMoreAgeLen() {
return this.$store.getters.getMoreAgeLen;
},
}

use

import {mapGetters } from "vuex";

...mapGetters({
getMore20:'getMore20',
getMore20Length:'getMore20Length',
getMoreAge:'getMoreAge',
getMoreAgeLen:'getMoreAgeLen'
}),
//数组写法
...mapGetters(['getMore20','getMore20Length','getMoreAge','getMoreAgeLen',]),
<h4>{{getMore20}}</h4>
<h4>{{getMore20Length}}</h4>
<h3>{{getMoreAge(20)}}</h3>
<h3>{{getMoreAgeLen(20)}}</h3>

mutions

大白话:同步修改state的值  写在vue 实例methods里面

更改 Vuex 的 store 中的状态(值)的唯一方法是提交 mutation。

Vuex 中的 mutation 非常类似于事件 methods:每个 mutation 都有一个字符串的 事件类型 (type) 和 一个 回调函数 (handler)。这个回调函数就是我们实际进行状态更改的地方,并且它会接受 state 作为第一个参数:

add是事件类型。

一条重要的原则就是要记住 mutation 必须是同步函数

//store.js 在mutations中修改state

mutations: {
add(state){
state.count+=5
},
decrease(state){
state.count-=5
},
// 提交载荷(接受其他参数),在大多数情况下,载荷是一个对象
addNum(state,payload){
state.count+=payload.num
},
decreaseNum(state,payload){
state.count-=payload.num
},
}

不用mapMutation。在methods里面通过this.$store.commit('xxx') 提交 mutation

 add(){
this.$store.commit('add')
},
decrease(){
this.$store.commit('decrease')
},
//注意:是在这里提交payload和mapMutation提交payload位置不同
addNum(){
this.$store.commit('addNum',{num:this.num}) //num是自己从data里面取出来的,
},
decreaseNum(){
this.$store.commit('decreaseNum',{num:this.num})
},
<button @click="add">add</button>
<button @click="decrease">jianfa</button>
<button @click="addNum">addNum</button>
<button @click="decreaseNum">decreaseNum</button>

mapMutation

使用mapMutation 同样两种方式。优先选择对象方式。

//对象方式
...mapMutations({
add:'add',
decrease:'decrease',
addNum:'addNum',
decreaseNum:'decreaseNum'
})
//数组方式
...mapMutations(['add','decrease','addNum','decreaseNum'])

使用 注意payload是在html中传的。

<button @click="add">add</button>
<button @click="decrease">jianfa</button>
<button @click="addNum({num:10})">addNum</button> //留心payload
<button @click="decreaseNum({num:10})">decreaseNum</button>

09vuex的更多相关文章

随机推荐

  1. iptables看门狗

    近来业内很多服务器因redis造成服务器被黑,这个攻击的防范重点在于防火墙!! 有时为了方便我们可能会将iptables临时关闭,方便完倘若忘记把它打开,黑客大摇大摆就走进来. 这时候,我们需要条看门 ...

  2. XSS 渗透思路笔记

    了解XSS首先要了解HTML里面的元素:共有5种元素:空元素.原始文本元素. RCDATA元素.外来元素以及常规元素. 空元素area.base.br.col. command. embed.hr.i ...

  3. JS学习第八天

    DOM访问列表框.下拉菜单的常用属性: form返回列表框.下拉菜单所在的表单对象; length返回列表框.下拉菜单的选项个数; options返回列表框.下拉菜单里所有选项组成的数组; defau ...

  4. 刚体验完RabbitMQ?一文带你SpringBoot+RabbitMQ方式收发消息

    人生终将是场单人旅途,孤独之前是迷茫,孤独过后是成长. 楔子 这篇是消息队列RabbitMQ的第二弹. 上一篇的结尾我也预告了本篇的内容:利用RabbitTemplate和注解进行收发消息,还有一个我 ...

  5. 2020-04-06:insert语句在mysql里经历了什么?

    1.会话状态转换为update 2.激活事物状态由 not_active 变为 active 3.查找定位数据 4.进行乐观插入 记录insert的undo记录记录undo的redo log 入red ...

  6. asp.netcore mvc 防CSRF攻击,原理介绍+代码演示+详细讲解

    一.CSRF介绍 1.CSRF是什么? CSRF(Cross-site request forgery),中文名称:跨站请求伪造,也被称为:one click attack/session ridin ...

  7. LeetCode 861翻转矩阵后得分详细解法

    1. 题目内容 有一个二维矩阵 A 其中每个元素的值为 0 或 1 . 移动是指选择任一行或列,并转换该行或列中的每一个值:将所有 0 都更改为 1,将所有 1 都更改为 0. 在做出任意次数的移动后 ...

  8. css如何让子元素在父元素中水平垂直居中

    方法一: display:flex <!DOCTYPE html> <html lang="en"> <head> <meta chars ...

  9. equals&hashCode

    经典规则:如果重写了equals,必须重写hashCode 为什么??? 这个规则考虑的应用场景:如果你的对象可能放入HashMap,HashSet,不重写会出问题 问题场景: new一个对象,重写了 ...

  10. Spark从入门到放弃---RDD

    什么是Spark? 关于Spark具体的定义,大家可以去阅读官网或者百度关于Spark的词条,在此不再赘述.从一个野生程序猿的角度去理解,作为大数据时代的一个准王者,Spark是一款主流的高性能分布式 ...