Vuex使用

在这里插入图片描述
项目根目录新建一个和src平级的store文件夹,里面新建index.js
在这里插入图片描述

// index.js
import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex)

export default new Vuex.Store({
  // 存放全局公用的数据
  state: {
    city: '上海'
  }
})

把存放全局都要使用的数据放进state里面

接着到main.js里把store导入:
在这里插入图片描述
通过this.$store.state.city可以访问到数据
在这里插入图片描述

在List.vue中给每个热门城市的按钮绑定一个点击事件
在这里插入图片描述
在这里插入图片描述
再通过this.$store.diapatch()方法把action分发出去,我们这里分发一个changeCity名字的Action,并且携带数据city的名字

在index.js中就要有相应的actions去接收分发出来的actions:
在这里插入图片描述
在这里插入图片描述
现在我们已经可以把我们想修改的值通过dispatch()分发action到Vuex里面的actions中了,接下来怎么改变这个数据?
在这里插入图片描述
通过actions中的changeCity的上下文ctx,可以发起一个commit
这个commit方法传入第一个参数是接下来需要执行的是哪个mutations的名字,我们这里通过ctx.commit('changeCityNow', city)指定要执行changeCityNow这个mutation,第二个参数指定传过去的内容是city

那么接下来就会执行changeCityNow这个mutation,这里面就把state这个公用数据里面的city改成了cityName

于是便完成了,效果如下
在这里插入图片描述

我们再看这张图
actions主要是执行一些异步的或者批量的复杂的任务,我们这里执行的是简单的任务,所以可以跳过Dispatch->Actions直接走Commit Mutations
在这里插入图片描述
所以我们可以这样写,把这部分actions删除:
在这里插入图片描述
再修改List.vue中的handleCityClick,把dispatch改为commit
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值