router.js的常用写法

本文介绍了Vue项目中路由的两种规范写法,包括如何减少代码量和明确父子组件层级。同时,讨论了vuescrollBehavior配置,确保在切换路由时能正确处理页面滚动位置。此外,还解决了可能出现的NavigationDuplicated问题,提供了一个避免该错误的解决方案。
摘要由CSDN通过智能技术生成

例如1:使用变量,减少代码量

{

        path: '/pages/:name', // 主页面,各列表页

        // name: 'mylist',

        component: () =>

            import ('@/dymatrixfrontweb/views/pageList/pageList.vue'),

        meta: { mainPage: true }

    }

例如2:规范写法,清晰明了,父子组件按层级

{

    path: '/',

    redirect: '/pages'

},

{、

    path: '/pages',

    component: () =>

        import('@/views/PagesView'),

    children: [{

        path: '',

        redirect: '/pages/BaseInstall'

    },

{

        path: 'baseInstall',

        name: 'baseInstall',

        component: () =>

            import('@/views/BaseInstall')

    },

]

}

vue scrollBehavior 切换到新路由时,页面要滚动到顶部或保持原先的滚动位置

const router = new Router({
    //   mode: 'history',
    routes,
    base: process.env.BASE_URL,
    scrollBehavior(to, from, savedPosition) {
        if (savedPosition) {
            return savedPosition
        } else {
            if (to.hash) {
                return {
                    selector: to.hash
                }
            }
            return { x: 0, y: 0 }
        }
    }
})

 当你的Vue项目在当前的路由下企图再次导航到当前路由时就会出现NavigationDuplicated的问题(通俗来讲就是多次进入了同一个path

const originalPush = Router.prototype.push
Router.prototype.push = function push(location) {
    return originalPush.call(this, location).catch(err => err)
}

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值