reactrouter监听路由变化_web前端框架vue的路由监听和路由守卫

220b146096d903acea4ea02d1b1db72b.png

路由监听:

//当一个组件被复用的时候,那么路由发生变化,但是页面上面的数据不会发生变化

新建one.vue 组件 作为home的子组件,在home.vue 中写遍历渲染页面 ,并用params传参,

one中 因为created只执行了一次,就接收都第一次传的值,所以需要监听

方案:

1、watch :{ "$route"(to,from){ this.name = to.params.name ; } }

to 中有params 属性,有name 和 id

from (从哪来,上一次点击的记录)

路由守卫2、路由守卫1 !!!

beforeRouteUpdate(to,from,next){ this.name = to.params.name ;next() }

to 中params 属性 有name 和id

next() 必加,to

3、路由守卫2 !!!离开时

beforeRouteLeave(to,from,next){ var flag = confirm("您确定要离开吗") if(flag){ next() }}

confirm 中,点击确定为true,取消为false;next必须

4、路由守卫3 !!!进入时

访问不到this,因为进入前 组件没有导入。调用next函数

beforeRouteEnter(to,from,next){

// 访问不到this,因为进入前组件没有导入,需要用到next

next((vm)=>{

// 通过ajax的success 接收后台传来的 登录状态

let flag = false;

if(!flag){

vm.$router.push("/login");

}else{

next();

} }

全局守卫:index.js 中

const router = new Router{ ... }

//验证用户的登录状态

router.beforeEach(to,from,next){

let flag = false;

//需要全局守卫的路由的name

let routers = ["find

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值