VueX状态管理器

cnpm i vuex axios -S
1 创建Vuex 仓库
import Vue from 'vue'
import Vuex from 'vuex'
vue.use(Vuex)
const store = new VueX.store({
state: {//存放状态},
mutations:{//唯一修改状态的地方,不在这里做逻辑处理}
})
export default store 2 在入口文件main.js下引入store
import store from './store/index.js'
将store 放到根实例里 以供全局使用
new Vue({
el:'#app',
store,
components:{App},
template:<App/>
})
开始使用store(以home组件为例)

Vuex的使用也是一种渐进式的,你可以从最简单的开始使用,根据经验和技术的增加,再渐进增强对它的使用,如果按照级别算vuex的使用可以从最基本的t1级别开始,先总结最基本的前三个版本,后续有时间再总结其他的

T1级别

1.
在hoome/script.js中进行请求数据
import Vue from 'vue'
import axios from 'axios'
export default {
mounted(){
axios.get('请求数据的接口')
.then((res)=>{this.$store.commit('changeList',res.data)})
//changeList相当于调用了在store.mutations中定义的修改状态的方法
//res.data 就是在改变状态时要修改的数据,需要在这传递过去。
.catch((err)=>{console,log(err)})
}
}
2.
在store/index.js中定义
import Vue from 'vue'
import Vuex from 'vuex'
vue.use(Vuex)
const store = new VueX.store({
state: {
//存放状态
list: [ ] //存放一个空的数组
},
mutations:{
//唯一修改状态的地方,不在这里做逻辑处理
//定义一个修改list的方法
//state 指上面存放list的对象,data 为在请求数据出传过来请求到的数据
changeList (state,data) {
state.list = data //将请求来的数据赋值给list
}
}
})
export default store 3.
在home/index.vue中渲染
<template>
//渲染数据的时候通过this.store.state.list直接从store中取数据
//还可以从其他组件通过这种方法去用这个数据无需重新获取
<li v-for='item of this.store.state.list' :key='item.id'>{{item.name}}</li>
</template> 注意点:

如果我们在home组件中获取的数据,可以在其他组件中使用,但是是当页面刷新默认进入home页,也就是相当于修改了数据,再点击其他页面也能有数据。如果我们在user组件中获取的数据要在home组件中使用,当页面刷新数据是不会显示的,因为此时还没有触发user组件中的更改数据的方法,所以数据为空,当点击user页面时,就会有数据,这个时候再去点击home页面我们就能够看到在home 组件中使用user组件中获取的数据了。解决这种问题的办法可以将数据存到本地一份或者都在首页进行请求数据

T2级别

在页面进行渲染的时候我们需要通过this.store.state去拿数据,这样的写法太长而且不太好
用计算属性结合mapState去解决这个问题
1
在home/script.js中进行操作
import Vue from 'vue'
import mapState from 'vuex'
import axios from 'axios'
export default {
computed:{
//mapState为辅助函数
...mapState(['list'])
},
mounted(){
axios.get('请求数据的接口')
.then((res)=>{this.$store.commit('changeList',res.data)})
.catch((err)=>{console,log(err)})
}
} 2
在home/index.vue中渲染
<template>
<li v-for='item of list' :key='item.id'>{{item.name}}</li>
</template>

T3级别



  使用常量去代替事件类型(便于查看状态,利于维护)
1
在store下创建mutation-type.js
export const CHANGE_LIST = 'CHANGE_LIST' 2
在store/index.js引入mutation-type.js
import Vue from 'vue'
import Vuex from 'vuex'
import {CHANGE_LIST } from‘./mutation-type.js’
vue.use(Vuex)
const store = new VueX.store({
state: {
list: [ ] //存放一个空的数组
},
mutations:{
//我们可以使用Es6风格的计算属性命名功能来使用一个常量作为函数名
[CHANGE_LIST] (state,data) {
state.list = data //将请求来的数据赋值给list
}
}
})
export default store 3
在home/script.js中进行引入
import Vue from 'vue'
import mapState from 'vuex'
import axios from 'axios'
import {CHANGE_LIST} from ‘../../store/mutation-type.js’
export default {
computed:{
//mapState为辅助函数
...mapState(['list'])
},
mounted(){
axios.get('请求数据的接口')
.then((res)=>{this.$store.commit(CHANGE_LIST,res.data)})
.catch((err)=>{console,log(err)})
}
}

VueX状态管理器 的应用的更多相关文章

  1. vue项目--vuex状态管理器

    本文取之官网和其他文章结合自己的理解用简单化的语言表达.用于自己的笔记记录,也希望能帮到其他小伙伴理解,学习更多的前端知识. Vuex 是什么? Vuex 是一个专为 Vue.js 应用程序开发的状态 ...

  2. vuex状态管理,state,getters,mutations,actons的简单使用(一)

    之前的文章中讲过,组件之间的通讯我们可以用$children.$parent.$refs.props.data... 但问题来了,假如项目特别大,组件之间的通讯可能会变得十分复杂... 这个时候了我们 ...

  3. 组件之间的通讯:vuex状态管理,state,getters,mutations,actons的简单使用(一)

    之前的文章中讲过,组件之间的通讯我们可以用$children.$parent.$refs.props.data... 但问题来了,假如项目特别大,组件之间的通讯可能会变得十分复杂... 这个时候了我们 ...

  4. vue状态管理器(用户登录简单应用)

    技术点:通过vue状态管理器,对已经登录的用户显示不同的页面: 一  vue之状态管理器应用 主要用来存储cookie信息 与vue-cookies一起使用 安装:npm install vue-co ...

  5. vuex状态管理-数据改变不刷新

    困惑: 在页面初始化的时候,我提交到vuex状态管理,然后在获取的时候获取不到,我找到了出错的地点,并进行了修改,然后可以获取到状态 但是不知道原因? 定义了如下的state const state ...

  6. 前端MVC Vue2学习总结(八)——Vue Router路由、Vuex状态管理、Element-UI

    一.Vue Router路由 二.Vuex状态管理 三.Element-UI Element-UI是饿了么前端团队推出的一款基于Vue.js 2.0 的桌面端UI框架,手机端有对应框架是 Mint U ...

  7. vuex状态管理demo

    vuex状态管理主要包含四个概念  mapState,mapMutations,mapGetters,mapActions. 编写vuex文件夹下面的store.js import Vue from ...

  8. 前端Vue框架-vuex状态管理详解

    新人报道!多多关照-多提宝贵意见 谢谢- vuex理解 采用集中式存储管理模式.用来管理组件的状态,并以自定义规则去观测实时监听值得变化. 状态模式管理理解 属性 理解 state 驱动应用的数据源 ...

  9. 前端技术之:如何在vuex状态管理action异步调用结束后执行UI中的方法

    一.问题的起源 最近在做vue.js项目时,遇到了vuex状态管理action与vue.js方法互相通信.互操作的问题.场景如下图所示: 二.第一种解决方法 例如,我们在页面初始化的时候,需要从服务端 ...

随机推荐

  1. 5)void万能指针

    函数参数为空,定义函数时,可以使用void来修饰:int fun(void) 函数没有返回值:void fun(void) 不同定义void类型的普通变量:void a     //原因是,无法确定类 ...

  2. 《杜拉拉升职记》//TODO

    目录 简介 杜拉拉升职记 杜拉拉2-年华似水 杜拉拉3-我在这战斗的一年里 杜拉拉大结局-与理想有关 结束语 简介 作者李可,女作家,某名校本科毕业,十余年外企生涯,职业经理人,"李可&qu ...

  3. PAT甲级——1058 A+B in Hogwarts

    1058 A+B in Hogwarts If you are a fan of Harry Potter, you would know the world of magic has its own ...

  4. linux安装源码包报错

    报错代码1如下: [root@xiaoming nginx-]# ./configure --prefix=/soft/nginx- checking for OS + Linux -.el7.x86 ...

  5. built?

    题目描述 There are N towns on a plane. The i-th town is located at the coordinates (xi,yi). There may be ...

  6. Date类与SimpleDateFormat类中parse()方法和format()方法

    package ppt11util类; import java.text.ParseException; import java.text.SimpleDateFormat; import java. ...

  7. pytest+allure高端测试报告

    1.下载jdk,搭建jdk环境 下载JDK  http://www.oracle.com/technetwork/java/javase/downloads/index.html 2.下载allure ...

  8. Qt 线程池QThreadPool类、QRunnable类

    QThreadPool类 用来管理 QThreads.此类中的所有函数都是线程安全的. 主要属性: 1.activeThreadCount: 此属性表示线程池中的活动线程数,通过activeThrea ...

  9. prisoners-of-war|

    The Nazi kept those ________ in their concentration camps.  A. prisoner-of-wars  B. prisoner-of-war ...

  10. DSU On Tree——Codeforces 600E(E. Lomsat gelral)

    有这么一类问题,要求统计一棵树上与子树相关的某些信息,比如:在一棵所有节点被染色的树上,统计每棵子树上出现次数最多的颜色编号之和. 很自然的可以想到用DFS序+主席树去求解,但是编码复杂度很高: 然后 ...