【Vue路由】props配置、replace属性、编程式路由导航、缓存路由组件
创始人
2024-05-05 08:06:12
0

文章目录

  • props配置
    • props值为对象
    • props值为布尔值
    • props值为函数
    • 总结
  • \的replace属性
    • 总结
  • 编程式路由导航
    • 案例实现
    • 总结
  • 缓存路由组件
    • 案例实现
    • 总结

props配置

我们可以看看我们原来如何使用传递过来的参数的:
在这里插入图片描述

我们要写一大长串去从$route身上拿到我们想要的数据,现在我们可以借助props配置简化代码。

props值为对象

在这里插入图片描述
然后我们使用的时候只需要注册一下就可以使用了,和父组件向子组件传递数据的那个props使用方法很相似:
在这里插入图片描述
但是这种方法有一些局限性,那就是传递的都是死数据。所以这种放使用的非常少。

props值为布尔值

在这里插入图片描述
然后我们注册id和title,就可以使用了:
在这里插入图片描述

这个方法的局限性也很明显,那就是只能接收到所有的params参数。你要是用query参数传过来的,那就使用不了

props值为函数

这个函数有一个特点:它可以从形参列表中拿到$route对象,有了$route对象,那我们基本上就可以上天下地无所不能。

在这里插入图片描述

其实这个方法就是把原来我们的代码逻辑移动到了另一个地方,让组件里面的代码不那么冗杂。

我们可以在这个方法的基础上利用js语法的特性使其更加精简:
使用js解构赋值:
在这里插入图片描述
使用解构赋值的连续写法:
在这里插入图片描述

总结

路由的props配置

作用:让路由组件更方便的收到参数

{name:'xiangqing',path:'detail/:id',component:Detail,//第一种写法:props值为对象,该对象中所有的key-value的组合最终都会通过props传给Detail组件// props:{a:900}//第二种写法:props值为布尔值,布尔值为true,则把路由收到的所有params参数通过props传给Detail组件// props:true//第三种写法:props值为函数,该函数返回的对象中每一组key-value都会通过props传给Detail组件props(route){return {id:route.query.id,title:route.query.title}}
}

的replace属性

我们可以看到我们的浏览器左上方有前进和后退键(edge只有后退键):
在这里插入图片描述

它是根据浏览器的历史记录进行工作的

我们以我们前文中的案例为例:
在这里插入图片描述

我们依次点击About、Home、News

浏览器的历史记录是采用栈的形式进行记录的,我们产生的历史记录会以push压栈的形式进入到栈中:
在这里插入图片描述
并且有一个指针指向当前所处页面。

我们每点击依次后退,这个指针就会向栈底的方向移动一位,我们现在可以后退三次:
在这里插入图片描述

如果我们再点击前进,指针又会向栈顶移动一位

对历史记录的操作除了push之外还有replace,也就是替换栈顶的一条记录:
在这里插入图片描述

也就是说我们依次点击About、Home、News之后,栈里面只有/home/news的记录。

默认我们的router-link是使用push方式添加历史记录,如果我们想以replace的方式,可以这样:
在这里插入图片描述

总结

的replace属性

  1. 作用:控制路由跳转时操作浏览器历史记录的模式
  2. 浏览器的历史记录有两种写入方式:分别为pushreplacepush是追加历史记录,replace是替换当前记录。路由跳转时候默认为push
  3. 如何开启replace模式:News

编程式路由导航

我们现在实现路由的跳转都是使用router-link标签,但是有的时候我们不能使用router-link,因为我们知道router-link的本质是a标签,如果此时我们是一个按钮,去用router-link进行路由跳转的话,这就造成了结构上的紊乱。

这个时候我们就要借助我们的路由器,去操作我们前面提到过的历史记录栈,来实现跳转。

我们以一个案例来进行说明

案例实现

在这里插入图片描述

因为是在前面的代码基础上进行的升级,所以我们只看看Message组件以及上面的前进后退按钮是怎么实现的。

首先我们要知道:我们自己实现路由跳转必须要借助$router原型对象上的方法:
在这里插入图片描述

Message.vue:


我们push和replace中传入的配置对象和我们在to中传入的对象一模一样。

再来看看我们的前进后退按钮:
Banner.vue:


说明:

这个go方法可以传入两种参数:

  • 如果传入的是正数,则向前进n次
  • 如果传入的是负数,则向后退n次

总结

编程式路由导航

  1. 作用:不借助 实现路由跳转,让路由跳转更加灵活

  2. 具体编码:

    //$router的两个API
    this.$router.push({name:'xiangqing',params:{id:xxx,title:xxx}
    })this.$router.replace({name:'xiangqing',params:{id:xxx,title:xxx}
    })
    this.$router.forward() //前进
    this.$router.back() //后退
    this.$router.go() //可前进也可后退
    

缓存路由组件

我们有的时候希望切换路由的时候,原路由不会被销毁。

例如下面这种情形:
在这里插入图片描述

我们在News组件中的每个li中加一个输入框,我们在输入框中打一个数字,然后我们切换到Message组件,此时我们再次切换回News组件的时候,我们发现我们输入框里面的东西已经没了。这就是因为News路由组件已经被销毁一次,我们使用的时候才创建。

那么我们怎么不让它被销毁呢?

案例实现

我们直接看Home组件(也就是News的父组件):

在这里插入图片描述

说明:

  • 如果不使用include属性,则此处呈现的路由组件都会被缓存
  • include里面放的是组件名
    在这里插入图片描述

    也就是这里的name后面跟的值

总结

缓存路由组件

  1. 作用:让不展示的路由组件保持挂载,不被销毁。

  2. 具体编码:

     
    
    

相关内容

热门资讯

安卓系统自带的网页,功能与特色... 你有没有发现,每次打开安卓手机,那熟悉的系统界面里总有一个默默无闻的小家伙——安卓系统自带的网页浏览...
美咖云系统安卓版,开启智能生活... 你有没有发现,最近手机上多了一个叫“美咖云系统安卓版”的小家伙?它就像一个魔法师,轻轻一点,就能让你...
安卓系统推荐最好的手机,盘点性... 你有没有想过,拥有一部性能卓越的手机,就像是拥有了移动的宝藏库?在这个信息爆炸的时代,一部好手机不仅...
安卓11系统能精简吗,释放潜能 你有没有发现,随着手机越来越智能,系统也越来越庞大?安卓11系统,这个最新的操作系统,是不是也让你觉...
安卓自动重启系统软件,揭秘原因... 手机突然自动重启,是不是感觉整个人都不好了?别急,今天就来和你聊聊这个让人头疼的安卓自动重启系统软件...
苹果手机x刷安卓系统,探索安卓... 你有没有想过,你的苹果手机X竟然也能刷上安卓系统?是的,你没听错,就是那个一直以来都和我们苹果手机X...
安卓系统智商低吗,智商低下的真... 你有没有想过,为什么安卓系统的智商总被调侃得好像有点低呢?是不是觉得它总是慢吞吞的,有时候还犯点小错...
安卓系统手机联系人,揭秘你的社... 你有没有发现,手机里的联系人列表就像是一个小小的社交圈呢?里面藏着我们的亲朋好友、工作伙伴,甚至还有...
安卓系统免费铃声下载,打造个性... 手机里那首老掉牙的铃声是不是让你觉得有点out了呢?别急,今天就来给你支个招,让你轻松给安卓手机换上...
安卓系统用哪个桌面好,打造个性... 你有没有发现,手机桌面可是我们每天都要面对的“脸面”呢?换一个好看的桌面,心情都能跟着好起来。那么,...
虚拟大师是安卓10系统,功能与... 你知道吗?最近在手机圈里,有个新玩意儿引起了不小的轰动,那就是虚拟大师!而且,更让人惊喜的是,这个虚...
安卓系统与苹果优缺点,系统优缺... 说到手机操作系统,安卓和苹果绝对是两大巨头,它们各有各的特色,就像两道不同的美味佳肴,让人难以抉择。...
安卓win双系统主板,融合与创... 你有没有想过,一台电脑如果既能流畅运行安卓系统,又能轻松驾驭Windows系统,那该有多爽啊?没错,...
安卓系统可精简软件,轻松提升手... 你有没有发现,手机里的安卓系统越来越庞大,软件也越装越多,有时候感觉手机就像个“大肚子”,不仅运行速...
安卓系统基于linux的代码,... 你有没有想过,那个陪伴你每天刷抖音、玩游戏、办公的安卓系统,其实背后有着一套复杂的基于Linux的代...
苹果和安卓的拍照系统,谁更胜一... 你有没有发现,现在手机拍照已经成为我们生活中不可或缺的一部分呢?无论是记录生活的点滴,还是捕捉美丽的...
苹果和安卓系统不同吗,系统差异... 你有没有想过,为什么你的手机里装的是苹果的iOS系统,而朋友的手机却是安卓系统呢?这两种系统,看似都...
安卓系统有多少级,揭秘其多级架... 你有没有想过,那个陪伴我们日常生活的安卓系统,它其实有着丰富的层级结构呢?没错,就是那个让我们的手机...
华为鸿蒙系统与安卓的,技术融合... 你知道吗?最近科技圈可是炸开了锅,华为鸿蒙系统与安卓的较量成为了大家热议的话题。这不,今天我就来给你...
什么安卓手机是苹果系统,搭载苹... 你有没有想过,为什么有些人宁愿花大价钱买苹果手机,而有些人却对安卓手机情有独钟呢?其实,这个问题背后...