下面小编就为大家分享一篇解决vue多个路由共用一个页面的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

在日常的vue开发中我们可能会遇见多个路由需要共用一个页面的需求,特别是当路由是通过动态添加的,不同的路由展示的东西只是数据不同其他没有变化。例如:

let routes = [
  {path:"/zhanshan",
  components:Person,
  },
  {path:"/lisi",
  components:Person,
  },
  {path:"/wangwu",
  components:Person,
  }
]

这种情况的时候,我们发现,其实我们的页面在第一次加载成功后就不会再加载了。所以页面一直显示第一次加载的数据,给人的赶脚好像路由没有生效,而我们通过观察浏览器地址栏中的变化可以确定的是这和路由没关系,这对刚刚开始使用的vue的同学可能会产生一点点困扰,其实这和页面的声明周期是相关的,这种情况出现的原因是因为页面在加载后他的大多数钩子函数(mounted,computed…)就不会再次出发了,所以导致页面感觉没有跳转。

一道这种业务需求其实也比较好处理,其实我们不需要页面切换,我们只需要页面中的数据发生改变就好了,我们可以在页面中监听路由地址的变化,当地址变化的时候,我们就重新加载数据。

watch:{
 "$route":function(to,from){
   //from 对象中包含当前地址
   //to 对象中包含目标地址
   //其实还有一个next参数的,这个参数是控制路由是否跳转的,如果没写,可以不用写next()来代表允许路由跳转,如果写了就必须写next(),否则路由是不会生效的。
 }
}

每当路由发生变化的时候上面的函数都会被触发,我们可以在这个函数中对页面的数据进行重新加载的操作。如果页面结构变化很大,还是建议单独新建一个不同的页面。

上面的问题可能对新入门vue的朋友有用,对vue比较了解了的朋友请绕过。

这篇解决vue多个路由共用一个页面的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持爱安网。

最新资讯
蔡文胜真的看好美图吗?

蔡文胜真的看好美图吗

仅凭蔡文胜这样的增持方式是不可能长久支撑美图股价的
中兴遭遇美国精确打击 缺芯的中国科技产业如何还击

中兴遭遇美国精确打击

中兴的主要产品是电信系统设备,其中最主要的就是无线基
让机器像人类一样多模态交互,会是物联网的胜负手吗?

让机器像人类一样多模

“AI of Things”在等待的,可能不仅是语音交互,而是耳目
第四季度苹果占全球手机利润86% iPhone X独占35%

第四季度苹果占全球手

Counterpoint数据显示,去年第四季度,全球手机市场的整体
别看软乎乎的!它们都是受宠的不正经机器人

别看软乎乎的!它们都是

甩开钢筋铁骨,机器人也开始玩软萌了。
聂卫平VS章文嵩是关公战秦琼? “等一等”算法才是大问题

聂卫平VS章文嵩是关公

聂卫平与章文嵩这场隔空论战,颇有一些“关公战秦琼”的
最新文章
vue加载自定义的js文件方法

vue加载自定义的js文

下面小编就为大家分享一篇vue加载自定义的js文件方法,
基于vue中css预加载使用sass的配置方式详解

基于vue中css预加载使

下面小编就为大家分享一篇基于vue中css预加载使用sass
js经验分享 JavaScript反调试技巧

js经验分享 JavaScrip

在这篇文章中,我打算跟大家总结一下关于JavaScript反调
基于vue.js实现的分页

基于vue.js实现的分页

本文主要给大家介绍基于vue的分页原生写法,代码分为htm
vue移动UI框架滑动加载数据的方法

vue移动UI框架滑动加

这篇文章主要介绍了vue移动UI框架滑动加载的方法,小编
解决vue-cli创建项目的loader问题

解决vue-cli创建项目

下面小编就为大家分享一篇解决vue-cli创建项目的loade