当前位置: 移动技术网 > IT编程>脚本编程>vue.js > Vue组件间通信 Vuex的用法解析

Vue组件间通信 Vuex的用法解析

2019年09月06日  | 移动技术网IT编程  | 我要评论

上回说到vue组件间通讯,最后留了一个彩蛋~~~vuex。vuex是另一种组件通讯的方法,这节来说说vuex(store仓库)。

首先vuex需要安装,安装的方式有很多,在这里就不一一细说了。我是通过npm方式安装的:

npm install vuex --save

安装好之后需要再main.js里全局引入:

import vue from 'vue'
import vuex from 'vuex'
vue.use(vuex)new vue({el:'#app',store,components: { app },template: '<app/>'})

这样就完成了vuex的安装。接下来就是vuex的用法了:

vuex有五个属性:state、getter、mutation、action、module。

1. state里放入的是仓库的数据,类似于js里的data:

import vue from 'vue'
const modules = {
 state:{
 name: '小白'
 }
 namespaced: true
}
export default modules

把vuex放入src下的store文件里,建一个新的组件modules,然后把他抛出来,被引入所需数据的组件:

<script>
import { mapstate }from 'vuex'
export default {
 computed:{
 // name(){
 // return this.$store.state.name
 // }
 ...mapstate(['name'])
 },
 mounted(){
 console.log(this.name)
 }
}
</script>

vuex里的数据需要从计算属性(computed)里获取,我写了两种我常用的方法,都可以接收到数据,在mounted钩子里打印出的数据:

这里只是举个例子教大家如何用,不建议大家向我这样去写,vuex应该用于所有业务逻辑的数据。不涉及到业务逻辑的,建议大家用上一章的方法:vue组件间通信。

2. getters里放入state里数据的扩展数据,可以把它当作计算属性。比如state里有一个数组,就可以从getters里获取到数组的长度,或是取到对象里面的属性,用法和计算属性类似:

import vue from ‘vue'

const modules = {
 state:{
 list:[
  {id :1,content: '第一条'},
  {id :2,content: '第二条'}
 ]
 },
 getter:{
 listlength: (state)=>{return state.list.length}
 },   namespaced: true}export default modules;

我在state里存了一个数组,然后getters计算出state里数组的长度,接下来就是在组件里接收了:

<script>
import { mapgetters } from 'vuex'
export default {
 compoted:{
 ...mapgetters(['listlength'])
 },
 mounted(){
 console.log(this.listlegth)
 }
}
</script>

打开控制台打印出2,就是list数组的长度。

3. mutations是保存在仓库的方法,这个方法只能用来改变state里面的数据,而且想要改变state里的数据只能用mutations里的方法,并且它里面的方法只能是同步的:

import vue from 'vue'

const modules = {
 state:{
 name: '小黑'
 },
 mutations:{
 changename(state){
  state.name = '小白'
 }
 },
 namespaced: true
}
export default modules;

还是那个例子,下面是组件调用方法:

<html>
<div>
 {{ name }}
 <el-button @click="changename">改变名字</el-button>
</div>
</html>
<script>
import { mapstate,mapmutations } from 'vuex'
export default {
 compoted:{
 ...mapstate(['name'])
 },
 methods:{
 ...mapmutations(['changename'])
 }
}
</script>

页面渲染后为:

点击按钮之后为:

组件里的按钮通过调用vuex里的mutation方法将vuex里的state数据改变,只不过mutations方法只能同步的,涉及到接口的就不能在它里面写,怎么办的?往下看:

4. actions和mutations一样都是vuex里的方法,只不过他们有两个最大的不同:

(1) actions里可以存放异步方法,而mutations只能放同步的;

(2) actions里不可以更改state里的数据,state里的数据只能在mutations里更改。

actions是什么方法?简单的说,它就是一个promise方法,通过不同的状态执行不同的方法,执行方法可以是actions里的方法,也可以是mutations里的方法。

actions我就不举例子了,因为大部分都用于axios请求接口,简单跟大家说说这个东西怎么使用:

import vue from 'vue'
import request from '@/api/axios'

const modules = {
 state:{
 list:[]
 },
 actions:{
 getlist({ commit }){
  // 调用接口方法
  request.getlist()
  .then((response)=>{
  // commit用来分配mutations方法
  commit('getlist',response)
  })
 }
 },
 mutations:{
 getlist(state,response){
  state.list = response.data
 }
 }
}

简单利用actions异步方法分配给mutations方法,然后在mutations方法里给state里的数据赋值,取到接口数据。

commit用于分配mutations方法,dispatch用于分配actions方法,都需要传参进去。

组件调用其实和调用mutations方法类似:

<script>
import { mapstate,mapactions } from 'vuex'
export default {
 computed:{
 ...mapstate(['list'])
 },
 mounted(){
 this.getlist()
 },
 methods:{
 ...mapactions(['getlist'])
 }
}
</script>

这样就基本完成了vuex传值。

5. module可以把vuex分为不同的模块,使业务逻辑变得更清晰,更准确。在上面的代码里,有const modules,给它不同的名字就是分为不同的模块。不同的module可以存入不同的数据和方法,使用起来非常方便。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网