vuex的传参使用

项目用到过好几次vuex,有的参数复用率较高,且不是父子组件,需要服用,所以考虑用vuex来进行传参

每一个模板都有自己的templateid 

 后端要求,在用户操作的时候每一步都请求接口,且要携带该模块的templateid参数

 首先在user.js文件构造mutations实例对象

                      

在页面内,找到能拿到templateid参数的页面

 先引入mapMutations

 

 接着在methods方法中,写入该方法

需要一个抛出这个参数的实例方法,页面中没有事件触发,所以写在mounted里

!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

!!!!!!!!!!!!!!!!!!!前方雷区!!!!!!!!!!!!!!!!!!!!

!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

原本以为vuex参数抛出去,接收参数的页面也要引入,但是不在data里定义实例的话,会报错没有参数的实例,但是定义了以后调用方法的时候又会报错参数已经在data中存在了,就很矛盾,跟同事闲聊的时候才知道,vuex是全局管理的,参数抛出去就相当于是vue的实例 ,在页面中直接赋值调用就可以,不需要引入,下面是之前错误的示范

 在需要接收参数的页面引入

要在computed里面写入要用的参数

 在需要接收参数的方法里,拿到state里的参数

 需要注意的是,在接收页面,需要在data里构造一个实例, 不然虽然可以接收到参数,但是会报错

但是在data中定义了实例后又会报错

 所以,参数抛出去直接在接收页面用就可以了

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值