vue3和vue2路由的变化 (轻松拿捏vue3)

1、路由 router 创建 区别

①vue3写法:----------------------------------

import { createRouter, createWebHistory } from 'vue-router'
const routerHistory = createWebHistory()
 const router = createRouter({
    history: routerHistory,
    routes: []
})
export default router

②vue2写法:-------------------------------------

import Vue from 'vue';
import VueRouter from 'vue-router';
Vue.use(VueRouter);
const router = new VueRouter({
  	routes: []
});
export default router;
2、动态添加路由 区别

①vue3写法:----------------------------------

//添加路由
router.addRouter({path:'/one',name:'one',component:()=> import('...page1.vue')}) 
//添加子路由
router.addRouter('one',{path:'/son1',name:'son1',component:()=> import('...son1.vue')})

②vue2写法:-----------------------------------

let routeA=[{ path: '/pageA', name: 'pageA',  component:()=> import('...pageA.vue')}]
router.addRoutes(routeA);
3、切换路由(router.push) 区别

①vue3写法:-----------------------------------

import { useRouter }  from  'vue-router'
setup(){
    const  router = useRouter()
    router.push('/');
    router.push({ path:'/aaa', params:{ username: 'posva'} });
}

②vue2写法:-----------------------------------

this.$router.push({path: '/bbb', query: {username: "abc"}});
4、路由守卫 区别

①vue3—>vue2未改变

router.beforeEach((to, from, next)=>{         })  beforeResolve 路由解析前  afterEach 路由跳转后执行
/* 逐个 (生命周期钩子) created一样  */
beforeRouteEnter((to, from, next)=>{         }) beforeRouteUpdate   beforeRouteLeave // vue3在setup函数外使用

②vue3新增

onBeforeRouteUpdate ,onBeforeRouteLeave
onBeforeRouteLeave((to, from, next)=>{
    const bool = window.confirm('你确定要离开当前页面吗?');
  	 if(!bool) {  return  false }
})
4、监听路由变化 区别

①vue3写法:-----------------------------------

import { useRoute }  from  'vue-router'
setup(){
    const route = useRoute();
    watch(route.query,(query)=>{ console.log(query); })
}

②vue2写法:-----------------------------------

watch:{
      '$route.path':function(newVal,oldVal){}
}

在这里插入图片描述

  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

野生切图仔

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值