vue使用this.$bus+keep-alive解决组件间跳转传参,参数无法保存问题

vue使用this.$bus+keep-alive解决组件间跳转传参,参数无法保存问题

前言

这是我在最近工作中经常遇到的问题,整理一下分享一波,希望大家也少踩坑。

问题描述

组件a使用this.$router.push({name: '组件b',params: '参数1'})传递参数并跳转到组件b后,组件b用this.$route.param获取到参数1,组件b跳转到组件c,并携带参数2再跳转回组件b,此时发现this.$route只能拿到参数2,拿不到参数1了。
原因就是组件b跳转到组件c又跳转回组件b,此时可以看做刷新了一次。
this.$route.param传递参数一般只用于简单的单项传递,且不能刷新,一刷新参数就没啦。

在这里插入图片描述

解决方法一:使用Vuex

每当出现组件传参问题时,我总会第一时间想到Vuex,Vuex确实能解决此类问题,但vuex适合大型项目跨组件储存数据,若数据量不是很大,且有很多这种问题则vuex里会储存的很杂很乱不好维护。之前看到过一句话,Vuex什么时候用?当你觉得你的项目可用可不用的时候,那就不要用。
所以这里我选择了另一种方法来解决这个问题。

解决方法二:使用bus+keep-alive

bus就是广播一个方法,方法里可以携带参数,然后任意组件都可以监听这个广播的方法,需要时接收广播并获取参数。功能和this.$router.push类似,只不过一个是定向跳转,一个可以随时接收。

  • bus的基础使用方法

1.在main.js定义bus,之后使用就直接`this.bus`

在这里插入图片描述

2.组件c广播事件
第180行this.$bus.$emit('itemCode', item)就是广播,参数1是广播的事件名,参数2是携带的参数。
第181行是路由跳回上一个路由。因为是从组件b跳到组件c,所以这里是跳回组件b。

在这里插入图片描述

3.组件b监听事件并接收参数
监听要在mounted生命周期里进行
第79行this.$bus.$on('itemCode', (item) => { })参数1itemCode是监听的事件名,参数2是一个函数,函数的参数是事件携带的参数item,可在函数体力进行数据处理操作,用箭头函数是处理this指向问题。
这里要注意第78行this.$bus.off('itemCode')是取消监听事件itemCode,监听事件时一定要在监听之前先取消这个监听事件,否则会导致下次重复监听,函数体里的操作会被执行多次。

在这里插入图片描述

  • bus与keep-alive联用处理参数无法保存问题
    此方法会解决最开始问题描述中的问题。

1.根据问题描述可以知道,只有组件b要对组件a的参数缓存,所以将组件bFilterShop添加进keep-alive中。
include里可以放缓存多个页面

在这里插入图片描述

2.组件a跳转到组件b并携带参数
组件a广播了一个事件workShop并携带参数this.workInfo,紧接着又使用this.$router.push跳转到组件b并传递参数this.workInfo。为何要这样写的原因之后再说。

在这里插入图片描述

3.组件b监听组件a和组件c广播的事件,且用$this.route.params接收组件a的参数
因为组件b在keep-alive里缓存了,所以组件b的生命周期改变,页面第一次进入,钩子的触发顺序created-> mounted-> activated,退出时触发deactivated。当再次进入(前进或者后退)时,只触发activated。
因为路由跳转的顺序是组件a -> 组件b -> 组件c -> 组件b,所以当组件a跳转到组件b时,拿不到监听组件a发出的方法的参数,所以组件a的参数要现在created里通过this.$route.params来获取,之后组件b跳转到组件c再跳转回来后,其他生命周期都不会触发,只触发activated钩子,此时的监听方法都会生效。所以组件a才需要写两种参数传递方法。
此时在组件b中,组件a和组件c传递的参数都能拿到,问题解决~。

在这里插入图片描述

总结

最近我经常用上面的方案二来解决类似的问题,把他分享给大家,并且如果有更好的方法或者我上面有什么说的不正确,也请大家多多指教。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,875评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,569评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,475评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,459评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,537评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,563评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,580评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,326评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,773评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,086评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,252评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,921评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,566评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,190评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,435评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,129评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,125评论 2 352

推荐阅读更多精彩内容

  • 原文://www.greatytc.com/p/0cdf51904afb 计算属性如何使用 一般我们在写...
    L_b115阅读 764评论 0 0
  • 计算属性如何使用 一般我们在写vue的时候,在模板内写的表达式非常便利,它运用于简单的运算,但是他也有一些复杂的逻...
    X秀秀阅读 13,751评论 1 19
  • Vue 3.0 性能提升主要是通过哪几方面体现的? vue2在初始化的时候,对data中的每个属性使用define...
    Smallbore阅读 1,161评论 0 8
  • 前言 组件是 vue.js最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着不同组件之间的数据无法相互引...
    用技术改变世界阅读 2,162评论 1 3
  • vue-cli搭建项目 确保安装了node与npm 再目标文件夹下打开终端 执行cnpm i vue-cli -g...
    Akiko_秋子阅读 3,223评论 1 22