更新记录

1.1.1(2019-12-12)

修复 返回上级页面时路由信息不对应的问题

1.1.0(2019-10-26)

  1. 增加pushTab()方法操作Tabbar跳转
  2. 可以拦截应用首次进入的路由了
  3. 示例项目完善相关操作(pushTab除外)

1.0.0(2019-10-25)

1.0.0

  1. 支持路由拦截功能
  2. 支持对象参数转换URL参数
查看更多

平台兼容性

bobo-router

bobo-router 是一个基于uni-app框架的路由拦截插件,本项目借鉴了uni-simple-router的思路,并对其进行简化,简化的原因是因为自己比较懒,不想每次新增页面就定义两遍路由表,所以bobo-router的特点就是纯粹的路由拦截,不再定义两遍路由表

当然,由于不再定义路由表,也损失了一些能力,比如不能使用命名路由,不能在路由表中自定义路由元信息等。

本人不是大神,插件可能会存在各种各样的问题,望大家谨慎使用,并多多担待。

安装

下载插件后,在main.js中导入即可。

// main.js

import router from './utils/bobo-router'

基本使用

uni-simple-router一样,项目中的路由跳转要全部弃用uni.navigateTo()这样的系统跳转方法,转而使用插件提供的this.$Router.push()这样的方法。

// *.vue

// 跳转页面,保留当前页到页面栈,等同于 uni.navigateTo()
this.$Router.push({
    page: '/pages/index/index',
    params: {}
})

// 跳转页面,替换当前页到页面栈,等同于 uni.redirectTo()
this.$Router.replace({
    page: '/pages/index/index',
    params: {}
})

// 跳转页面,清空页面栈,等同于 uni.reLaunch()
this.$Router.replaceAll({
    page: '/pages/index/index',
    params: {}
})

// 跳转 Tabbar,等同于 uni.switchTab()
this.$Router.pushTab({
    page: '/pages/index/index',
    params: {}
})

Tips: 如果不需要传递参数,可以直接使用 this.$Router.push('/pages/index/index')

注意: pushTab传递的参数可通过this.$Route.params获取,但h5页面刷新之后就会丢失数据

路由拦截

支持路由前置守卫和路由后置守卫,并且提供一个路由跳转失败的回调,可以重写以实现自己的逻辑。

bobo-router/index.js中添加自己的拦截逻辑。

// ./utils/bobo-router/index.js

// 路由全局拦截器 在这里处理登录、授权等相关操作
router.beforeEach(function(to, from, next) {
    console.log('前置守卫')
    // to.page不存在表示此次路由跳转仅为了执行路由守卫,若不需处理则直接放行,就不会执行任何路由操作了
    if (from.page === '/pages/plugin/routers/r3' && !to.page) {
    // 测试小程序跳转
    // if (from.page === '/pages/index/index' && !to.page) {
        next({page: '/pages/plugin/routers/r4', params: {
            message: '我是从路由3刷新跳过来的'
        }, method: 'redirectTo'})
    } else {
        next()
    }
})

// 路由后置拦截器 在这里处理用户高频操作信息
router.afterEach(function (to, from) {
    console.log('后置守卫')
})

// 路由跳转出错处理
router.onError(function(e) {
    console.log('错误:', e.message || '路由跳转失败')
})

参数解释:

to:目标路由信息,包含method路由跳转方式、page页面地址和params页面参数

注:在进入应用的第一个页面或h5刷新页面后会执行路由前置守卫,此时 to 中的属性均为 undefined

from:当前路由信息,包含page页面地址和params页面参数

next:下一步操作

  • next(false) 中断路由跳转
  • next('/pages/index/index') 执行指定页面的路由前置守卫,若当前操作指定过跳转方式,则使用该跳转方式,否则使用默认的push进行跳转
  • next({page:'/pages/index/index',params:{},method:''}) 执行指定页面的路由前置守卫,method传入跳转方式,也可以不指定,效果同直接传入页面地址
  • next() 放行 执行跳转操作

参数解析

使用本插件的方法去跳转路由,会将对象的第一级属性转换到URL中,深层对象则转为json串放在对应的属性中。

例如:

// 转换前对象
{
    num: 19,
    numStr: '19',
    testParams: true,
    deepObj: {
        str: 'hahaha'
    },
    ignoreFun: function() {
        console.log('i\'m hide.')
    },
    testUndefined: undefined,
    testNull: null
}

// 转换后URL
?num=19&numStr=19&testParams=true&deepObj=%7B"str"%3A"hahaha"%7D&testUndefined=&testNull=

如果要获取当前路由信息,可通过this.$Route获取。

{
    "path": "/pages/plugin/router?num=19&numStr=19&testParams=true&deepObj={\"str\":\"hahaha\"}&testUndefined=&testNull=",
    "params": {
        "num": 19,
        "numStr": "19",
        "testParams": true,
        "deepObj": {
            "str": "hahaha"
        },
        "testNull": null
    },
    "page": "/pages/plugin/router",
    "pageTitle": "路由拦截插件"
}

页面标题 pageTitle 是在页面中的 data(){}代码块中定义了之后才能正常显示,且只能在onload生命周期之后使用。 h5端则不需要定义pageTitle,插件可直接获取当前网页标题。

隐私、权限声明

1. 本插件需要申请的系统权限列表:

2. 本插件采集的数据、发送的服务器地址、以及数据用途说明:

3. 本插件是否包含广告,如包含需详细说明广告表达方式、展示频率:

许可协议

MIT协议

使用中有什么不明白的地方,就向插件作者提问吧~ 我要提问