更新记录

1.1.12(2024-08-06) 下载此版本

  • 修复导航守卫因返回 false 取消导航插件锁定全局导航导致导航方法全都失效的问题。
  • 优化其他已知问题。

1.1.11(2024-08-05) 下载此版本

  • 修复 pagesJsonRouter 自动生成 condition 时缺少逗号导致编译失败的问题。

1.1.10(2024-08-05) 下载此版本

  • 优化 router.uts 默认生成逻辑,解决默认生成的内容编译安卓报错的问题。
  • 优化 pagesJsonPlugin 参数类型,调整为可选参数。
  • 优化其他已知问题。
查看更多

平台兼容性

Vue2 Vue3
×
App 快应用 微信小程序 支付宝小程序 百度小程序 字节小程序 QQ小程序
HBuilderX 3.6.8,Android:4.4,iOS:支持 × × × × × ×
钉钉小程序 快手小程序 飞书小程序 京东小程序
× × × ×
H5-Safari Android Browser 微信浏览器(Android) QQ浏览器(Android) Chrome IE Edge Firefox PC-Safari

kux-router

kux-router 是一个参考 vue-router 的api设计实现的 uts 路由库,支持 vue-router 的绝大数功能特色,如全局路由自定义 routes 配置,beforeEachafterEach 等全局导航守卫,路由元信息等丰富的 api 供开发者灵活使用。

注意:
由于 uts 为强类型语言,所以涉及自定义传参的都要手动指定类型,所有参数类型都已经导出,开发者直接根据提示直接导入使用即可。

v1.1.0 为全新重构的版本,旧版本升级时请仔细查看版本更新日志,升级过程有什么问题可以进群交流:870628986

v1.1.5 及以上版本开始支持 uni 全局挂载方式。参考 uni 全局挂载

插件特色

  • 完全对齐 vue-router 的API设计用法。
  • 支持多种导航守卫。
  • 支持应用启动拦截守卫。
  • 支持路由返回守卫。
  • 支持异步拦截守卫。
  • 支持组件式用法,需下载 kux-router-link
  • 自动生成 pages.json 路由配置映射。
  • 支持 uni ext api用法。【需升级插件到v1.1.5或以上版本】
  • ...其他更多优秀的工具方法。

官网全新上线:https://router.uvuejs.cn

开源地址:https://gitcode.com/kviewui/kux-router

目录结构

基础

安装配置

本插件为完全的 uni_modules 插件,所以直接在 插件市场 搜索 kux-router 安装即可。

  • 项目根目录创建 vite.config.ts, 配置内容如下:

    import { defineConfig } from 'vite';
    import uni from "@dcloudio/vite-plugin-uni";
    import pagesJsonPlugin from './uni_modules/kux-router/vite/vite-plugin-kux-pages-json.ts';
    
    export default defineConfig({
        plugins: [
            uni(),
            pagesJsonPlugin
        ],
    });

    提示

    • v1.1.0 及以下版本不需要配置这个。
    • 项目根目录存在该文件时,不需要重新建创建该文件,直接按照上面示例配置 pagesJsonPlugin 插件即可。

入门使用

main.uts 全局挂载

下载该 uni_modules 插件到自己的项目中后,可以直接在项目根目录的 main.uts 进行全局引入挂载,方便后面直接调用,示例代码如下:

  • v1.1.0 及以上版本用法

    由于新版的底层全面重构,所以在初始化的时候自动做了 pages.json 路由映射,会在项目根目录自动生成 pagesJsonRouter.uts 文件,方便创建路由实例时自动根据该映射配置创建 routes 路由池。具体操作如下:

    • 项目根目录创建 router.uts 文件,初始化内容参考下面示例代码。

      import { pages } from '@/pagesJsonRouter';
      import { RouteRecordNormalized } from '@/uni_modules/kux-router/utssdk/interface';
      // 这个是全局 `store` 状态管理内容,可以根据自己的项目灵活引入使用。
      import { state } from '@/store/index';
      
      // 初始化路由池信息
      let routes: RouteRecordNormalized[] = [];
      // 遍历pages映射创建路由池信息
      pages.map((item) => {
          switch (item.path) {
              case '/pages/p1/p1':
                  routes.push({
                      path: item.path,
                      // name为可选,如果后面想通过该路由的名称跳转时记得要在这里传 `name`
                      name: item.name,
                      // query为可选,一般用来设置全局query参数的场景
                      query: {
                          e: 1,
                          f: 2
                      } as UTSJSONObject,
                      redirect: (to): RouteRecordNormalized | null => {
                          // 测试判断是否登录
                          if (state.token1.length == 0) {
                              return {
                                  name: 'PagesP1Login'
                              } as RouteRecordNormalized;
                          }
      
                          return null;
                      }
                  } as RouteRecordNormalized);
                  break;
              case '/pages/demo/indexInterceptor/indexInterceptor':
                  routes.push({
                      path: item.path,
                      name: item.name,
                      // 测试未登录启动首页拦截
                      beforeEnter: (async (to, from): Promise<any | null> => {
                          if (state.token3.length == 0) {
                              let s = 3;
                              let timer: number = 0;
                              timer = setInterval(() => {
                                  if (s <= 0) {
                                      clearInterval(timer);
                                  } else {
                                      uni.showToast({
                                          title: `${s}秒后自动拦截到登录页面`,
                                          icon: 'none',
                                          position: 'center'
                                      });
                                  }
                                  s--;
                              }, 1000);
                              const delay = async (): Promise<number> => {
                                  return new Promise<number>((resolve) => {
                                      setTimeout(() => {
                                          resolve(0);
                                      }, 5000);
                                  })
                              }
      
                              await delay();
      
                              return {
                                  name: 'PagesDemoIndexInterceptorLogin'
                              } as RouteRecordNormalized;
                          }
      
                          return null;
                      }),
                  } as RouteRecordNormalized);
                  break;
              // 不需要做自定义导航守卫的记得要在这里获取映射配置内容并传给 `routes`
              default:
                  routes.push({
                      path: item.path,
                      name: item.name
                  } as RouteRecordNormalized);
          }
      });
      
      export default routes;

      提示

      router.uts 文件为全局导航守卫和路由配置文件,后面所有需要全局导航守卫或者设置路由信息,比如 name 路由别名,meta 路由元信息,query 全局路由URL参数,data 全局路由自定义参数等内容时只需要在该文件设置即可。

      从上面路由配置流程可以看出来只有需要自定义全局导航守卫和路由配置信息的时候才需要根据路由地址设置单独的 switch case条件,其他只需要设置 default 中的配置即可。

    • main.uts 全局挂载

      import App from './App.uvue'
      
      import { createSSRApp } from 'vue'
      import { createRouter } from '@/uni_modules/kux-router';
      import { RouterOptions } from '@/uni_modules/kux-router/utssdk/interface';
      import routes from './router';
      
      export function createApp() {
          const app = createSSRApp(App)
          const router = createRouter({
              routes: routes
          } as RouterOptions);
          // 组合式API建议通过如下方式挂载
          app.provide('router', router);
          // 选项式API可以通过如下方式挂载
          // app.config.globalProperties.kuxRouter = router;
          return {
              app
          }
      }
  • v1.1.0 以下版本用法

    import App from './App.uvue';
    
    import { createSSRApp } from 'vue';
    // 引入 kux-router 路由库
    import {createRouter} from '@/uni_modules/kux-router';
    
    export function createApp() {
        const app = createSSRApp(App);
        // 通过 app.use 全局挂载路由库,这里建议使用有意义的且不容易和全局内置变量冲突的名字,我测试中发现是不能使用 `router` `route` `$route` 这些名字
        app.config.globalProperties.kuxRouter = createRouter();
        return {
            app
        }
    }

提示
为了方便统一话术,上面的 kuxRouter 在下文中统称为 router,下文所有实例名称为 router,实际使用过程请参考自己全局挂载的方式和名称。

uni 全局挂载

请参考 uni 全局挂载

页面调用

router.push('/pages/p1/p1');

编程式导航

我们可以通过 router 的实例方法来自定义跳转到导航的页面。

导航到不同的位置

想要导航到不同的 URL,可以使用 router.push 方法。这个方法会向路由栈添加一个新的记录。

  • v1.1.0 及以上版本用法

    该方法有一个参数,参数类型支持多种,具体类型说明如下:

    类型名 默认值 说明
    RouteRecordPath - 路由地址,该类型会在重新编译的时候根据pages.json自动更新
    RouteRecordNormalized - 创建路由表时的路由配置信息
  • v1.1.0 以下版本用法

    该方法的参数有两个,第一个参数为 必填 的页面路径,第二个参数为 可选 的路由配置项,结构如下:

    参数名 是否必填 类型 默认值 说明
    to string - 即将访问的页面路径
    options RouteLocationRaw 见下方 {} 跳转页面时的配置项,如页面传参信息

注意
由于 uts 支持的联合类型有严格的限制,所以无法实现 vue-router 的那种可变类型传参,所以第一个参数必须填写。

v1.1.0 及以上版本由于底层进行了重构,所以参数支持多种类型。

RouteLocationRaw 说明

参数名 是否必填 类型 默认值 说明
query UTSJSONObject {} 页面 query 传参,会被路由库自动转为 query string 字符串参数拼接到页面地址后面

注意
由于 uniapp x 目前不支持自定义路由,也不支持动态路由,所以暂时不支持 vue-routerparams 传参。

  • v1.1.0 及以上版本

    // 路径直传
    router.push('/pages/user/list');
    
    // 对象方式跳转,可以指定 `query` 参数,`data` 参数等其他内容
    router.push({
        path: '/pages/user/info',
        query: {
            id: 1
        },
        data: {
            member_id: 30
        }
    } as RouteRecordNormalized);
  • v1.1.0 以下版本

    // 没有参数跳转
    router.push('/pages/user/list');
    
    // 带参数跳转,由于 uts 为强类型语言,`{}` 对象参数默认是 `UTSJSONObject` 类型,所以带参数时需要手动指定 `RouteLocationRaw ` 类型
    import {RouteLocationRaw} from '@/uni_modules/kux-router';
     router.push('/pages/user/info', {
        query: {
            id: 1
        }
    } as RouteLocationRaw);

横跨历史

该方法采用一个整数作为参数,表示在历史堆栈中后退多少步,其实就是 uni.navigateBack
例子

// 返回1条记录,与 uni.navigateBack() 相同
router.back();

// 返回 3 条记录,与 uni.navigateBack({delta: 3}) 相同
router.back(3);

命名路由

除了 to 之外,还可以通过路由的 name 进行跳转。主要应用于 routes 中的路由重定向。

import {RouteRecordNormalized} from '@/uni_modules/kux-router';
const routes = [
    {
        path: '/pages/user/info',
        name: 'UserInfo'
    }
] as RouteRecordNormalized[];

要跳转到一个命名的路由,可以参考 重定向 介绍。

重定向

重定向也是通过 routes 配置来完成,下面例子是从 /home 重定向到 /

  • v1.1.0 及以上版本

    import {RouteRecordNormalized} from '@/uni_modules/kux-router';
    const routes = [
        {
            path: '/home',
            redirect: (_): RouteRecordNormalized | null => {
                return {
                    path: '/'
                } as RouteRecordNormalized;
            }
        },
        {
            path: '/'
        }
    ] as RouteRecordNormalized[];
  • v1.1.0 以下版本

    import {RouteRecordNormalized, RouteRecordRedirect} from '@/uni_modules/kux-router';
    const routes = [
        {
            path: '/home',
            redirect: (_): RouteRecordRedirect => {
                return {
                    path: '/'
                } as RouteRecordRedirect;
            }
        },
        {
            path: '/'
        }
    ] as RouteRecordNormalized;

重定向的目标也可以是一个命名的路由:

  • v1.1.0 及以上版本

    import {RouteRecordNormalized} from '@/uni_modules/kux-router';
    import { state } from '@/store/index';
    
    routes.push({
        path: '/pages/p1/p1',
        name: item.name,
        query: {
            e: 1,
            f: 2
        } as UTSJSONObject,
        redirect: (to): RouteRecordNormalized | null => {
            // 测试判断是否登录
            if (state.token1.length == 0) {
                return {
                    name: 'PagesP1Login'
                } as RouteRecordNormalized;
            }
    
            return null;
        }
    } as RouteRecordNormalized);
  • v1.1.0 以下版本

    import {RouteRecordNormalized, RouteRecordRedirect} from '@/uni_modules/kux-router';
    const routes = [
        {
            path: '/home',
            redirect: (_): RouteRecordRedirect => {
                return {
                    name: 'homepage'
                } as RouteRecordRedirect;
            }
        },
        {
            path: '/homepage',
            name: 'homepage'
        }
    ] as RouteRecordNormalized;
    

注意
1.重定向的路由必须要在 routes 中配置过才可以,如示例上面的配置即可。
2.目前重定向是通过 redirect 动态方法实现,因为 uts 不支持自定义的联合类型,所以无法实现 vue-router 中的字符串路径参数进行重定向。

进阶

导航守卫

kux-router 提供的导航守卫主要用来通过跳转或取消的方法守卫导航。目前支持全局导航守卫和路由配置全局守卫两种方式。

全局前置守卫

你可以使用 router.beforeEach 注册一个全局前置守卫:

  • v1.1.0 及以上版本

    import { RouteRecordNormalized } from '@/uni_modules/kux-router';
    
    router.beforeEach(async (to, from): Promise<any | null> => {
        if (from?.path == '/home') {
            return {
                path: '/homepage'
            } as RouteRecordNormalized;
        }
    
        return null;
    })

    提示

    beforeEach 返回一个可以用来移除自身的函数,如果需要移除该守卫,可以在使用完守卫后直接调用自身函数,示例代码如下:

     router.beforeEach(async (to, from): Promise<any | null> => {
      if (from?.path == '/home') {
          return {
              path: '/homepage'
          } as RouteRecordNormalized;
      }
    
      return null;
    })();  // 这里最后调用自身即可移除该守卫
  • v1.1.0 以下版本

    import {NavigationGuardReturn, RouteLocationGuardReturnOptions} from '@/uni_modules/kux-router';
    router.beforeEach(async (to, from) => {
        // 这里可以根据 to 和 from 信息来灵活跳转页面
        if (from.path === '/home') {
            return {
                to: {
                    path: '/homepage'
                } as RouteLocationGuardReturnOptions
            } as NavigationGuardReturn
        }
    });

    注意
    因为 uts 强类型语言,不支持自定义联合类型,所以无法实现 vue-router 那种异步和同步同时共用一个参数位置的形式,目前只能统一使用 async 同步拦截方式,后面会提供异步拦截的 API

全局后置钩子

你也可以注册全局后置钩子,和前置守卫不同的是后置钩子不需要返回类型,一般用来做路由跳转后的日志统计信息。

router.push('/pages/p1/p1');
// 模拟路由后置钩子记录日志
router.afterEach((to, from) => {
    console.log(`页面 ${from.path} 跳转到了页面 ${to.path}`);
});

提示

v1.1.0 及以上版本该守卫返回一个用来移除自身的函数,可以直接调用自身来移除该守卫。

路由独享的守卫

你可以直接在路由配置上定义 beforeEnter 守卫:

  • v1.1.0 及以上版本

    import { RouteRecordNormalized } from '@/uni_modules/kux-router';
    const routes = [
        {
            path: '/pages/p5/p5',
            beforeEnter: (async (_, _): Promise<any | null> => {
                return {
                    path: '/pages/p6/p6'    
                } as RouteRecordNormalized;
            })
        }
    ] as RouteRecordNormalized[];
  • v1.1.0 以下版本

    import {RouteRecordNormalized, RouteLocationGuardReturnOptions, NavigationGuardReturn} from '@/uni_modules/kux-router';
    const routes = [
        {
            path: '/pages/p5/p5',
            beforeEnter: (async (_, _): Promise<NavigationGuardReturn> => {
                return {
                    to: {
                        path: '/pages/p6/p6'
                    } as RouteLocationGuardReturnOptions
                } as NavigationGuardReturn;
            })
        }
    ] as RouteRecordNormalized[];

完整的守卫解析流程

  • 检测 routes 配置中是否有 redirect 重定向,有的话执行重定向。
  • 检测 routes 配置中是否有 beforeEnter 守卫,有的话执行守卫。
  • 检测全局的 beforeEach 守卫,如果定义了就执行守卫。
  • 检测全局的 afterEach 守卫,如果定义了就执行守卫。

路由元信息

有时你希望将自定义的任意信息添加到路由上,如是否需要授权的场景,通过路由配置对象的 meta 属性可以实现前面的需求,并且它会被记录在全局路由配置状态中,路由信息和导航守卫都可以访问到。定义路由的时候你可以这样配置 meta 字段:

import {RouteRecordNormalized} from '@/uni_modules/kux-router';
const routes = [
    {
        path: '/pages/posts/new',
        meta: {
            // 只有经过身份认证的用户才能创建帖子
            requiresAuth: true
        }
    },
    {
        path: '/pages/posts/info',
        meta: {
            // 任何人都可以阅读
            requiresAuth: false
        }
    }
] as RouteRecordNormalized[];

这时候你可以通过 beforeEach 全局前置守卫来检查是否授权

  • v1.1.0 及以上版本

    import { RouteRecordNormalized } from '@/uni_modules/kux-router';
    
    router.beforeEach(async (to, from): Promise<any | null> => {
        if (to?.meta?.get('requiresAuth') == true && !auth.isLoggedIn()) {
            // 此路由需要授权,请检查是否已登录
            // 如果没有,则重定向到登录页面
            return {
                path: '/pages/login/index',
                // 保存现在的位置,方便后面跳回来
                query: {
                    redirect: to.fullPath
                }
            } as RouteRecordNormalized;
        }
    
        return null;
    });
  • v1.1.0 以下版本

    import {NavigationGuardReturn, RouteLocationGuardReturnOptions} from '@/uni_modules/kux-router';
    
    router.beforeEach(async (to, from): Promise<NavigationGuardReturn> => {
        if (to.meta.requiresAuth && !auth.isLoggedIn()) {
            // 此路由需要授权,请检查是否已登录
            // 如果没有,则重定向到登录页面
            return {
                to: {
                    path: '/pages/login/index',
                    // 保存现在的位置,方便后面跳回来
                    query: {
                        redirect: to.fullUrl
                    }
                } as RouteLocationGuardReturnOptions
            } as NavigationGuardReturn;
        }
    });

组合式API

访问路由和当前路由

虽然推荐使用方式是 main.uts 全局挂载,不过路由库还是像 vue-router 一样提供了 useRouteruseRoute 函数:

import {useRouter, useRoute} from '@/uni_modules/kux-router';

const router = useRouter();
const route = useRoute();

router.push('/pages/user/info');

// 获取当前路由信息
console.log(route);

注意
通过 router.currentRoute() 也能获取到当前路由信息,和 useRoute 是完全一样的。

useRoute 路由信息参数说明

参数名 参数类型 说明
query UTSJSONObject 当前路由 query 参数
params UTSJSONObject 当前路由 params 参数,该参数在 v1.1.0 及以上版本被废弃,替换为 data 属性
path string 当前路由页面地址,这个是去除参数后的地址,如:/pages/user/info
fullUrl string 当前路由页面带参数的完整地址,如:/pages/user/info?id=1,该参数在 v1.1.0 及以上版本被废弃,请替换为 fullPath 属性
meta UTSJSONObject routes 配置中的路由元信息,如果没有自己配置,该参数为 null
datav1.1.0 UTSJSONObject 路由隐式传参,即路由参数不在地址栏中展现的参数,用来替代旧版本的 params
fullPathv1.1.0 string 该属性替代旧版本的 fullUrl
namev1.1.0 RouteRecordName 路由名称
fromv1.1.0 RouteLocationNormalizedLoaded 从哪个页面跳转过来的
tov1.1.0 RouteLocationNormalizedLoaded 要到哪个页面去,一般用于路由拦截后完成某些操作再重定向到目标页面的场景

RouterLink

v1.1.0 及以上版本提供了组件标签式的路由跳转导航守卫使用方式,需要单独下载 kux-router-link 插件。路由实例的所有导航守卫对该组件都生效。

属性

名称 类型 默认值 描述
to string(string.PageURIString) - 要前往的页面地址,支持带query参数,如:/pages/user/info?id=1
openType 'push' | 'replace' | 'switchTab' | 'reLaunch' 'push' 导航方式,见下方说明
options RouteRecordNormalized - 编程式导航页面信息,在导航跳转时以对象方式设置更多参数信息,如 data 隐式传参,meta 元信息等等。见下发说明

OpenType 说明

名称 说明
push 对应 router.push()
replace 对应 router.replace()
switchTab router.switchTab()
reLaunch 对应 router.reLaunch()

示例代码

<kux-router-link to="/pages/demo/pageCompInterceptor/pageCompInterceptor">
    <button type="primary">页面组件拦截示例</button>
</kux-router-link>

uni 全局挂载

插件通过vite自动生成了 uni ext api 的封装插件来实现了直接挂载 uni 对象。具体操作如下:

  • vite.config.ts 修改如下:
import { defineConfig } from 'vite';
import uni from "@dcloudio/vite-plugin-uni";
import generateUniext from './uni_modules/kux-router/vite/vite-plugin-generate-uniext'
import pagesJsonPlugin from './uni_modules/kux-router/vite/vite-plugin-kux-pages-json.ts';

export default defineConfig({
    plugins: [
        generateUniext,
        uni(),
        pagesJsonPlugin
    ],
})
  • 然后项目中即可直接使用:
    • uni.useKuxRouter 来替代原来的手动导入 useRouter
    • uni.useKuxRoute 来替代原来的手动导入 useRoute
    • uni.createKuxRouter 来替代原来的手动导入 createRouter

提示

v1.1.5 及以上版本支持。

上面的 generateUniext 为新增的导入模块。模块初始化时会在 uni_modules 目录下面生成 uni-kuxrouter 插件,该插件第一次生成时需要编译两次才能正常使用。该插件存在时按照正常的编译一次即可。

介意上面第一次需要编译两次的谨慎使用 uni 全局挂载方式。

API参考

函数

createRouter

创建一个 KuxRouter 实例。

提示

v1.1.0 及以上版本实例名称为 IRouter

参数

名称 类型 描述
options RouterOptions RouterOptions

返回值

KuxRouter

RouterOptions 说明

用来初始化一个 KuxRouter 实例的选项。

属性

routes

添加到路由器的初始路由列表。一般用来做 路由元信息 配置时才需要手动设置它。

  • debug: boolean

用来开启关闭路由库调试。

RouteRecordNormalized 说明

routes 的路由配置信息。

属性

beforeEnter

被注册的 beforeEnter 守卫。

NavigationGuardWithThis 说明

导航守卫。详情可看导航守卫

参数

名称 类型
to RouteLocationNormalizedLoaded
from RouteLocationNormalizedLoaded

返回值

Promise<NavigationGuardReturn>

RouteLocationNormalizedLoaded 说明

属性

query

  • query:UTSJSONObject

当前路由的 query 传参。

params

  • params:UTSJSONObject

当前路由的 params 传参。目前没用到该属性。

path

  • path:string

当前路由去除 query 参数后的页面地址。

fullUrl

  • fullUrl:string

当前路由带 query 参数的完整页面地址。

meta

  • meta:UTSJSONObject

routes 配置中当前路由匹配的 路由元信息

KuxRouter/IRouter 说明

路由器实例。

属性

options

  • options: RouterOptions | null

创建路由器时的原始选项对象。

提示

v1.1.0 及以上版本支持。

from

  • from: RouteLocationNormalizedLoaded | null

获取即将离开的路由信息。

提示

v1.1.0 及以上版本支持。

方法

addRoute

动态增加routes配置中的路由信息。

参数

名称 类型 描述
routeRecord RouteRecordNormalized routes 的路由配置信息。

返回值

void

说明

v1.1.0 及以上版本该方法将被废弃,由路由库提供新的自动化解决方案替代。

currentRoute

参数

void

返回值

RouteLocationNormalizedLoaded

afterEach

  • afterEach(guard): () => void

路由跳转后的守卫。

参数

名称 类型 描述
guard NavigationHookAfter 要加入的导航钩子

NavigationHookAfter

  • NavigationHookAfter(to, from): void

参数

名称 类型
to RouteLocationNormalizedLoaded
from RouteLocationNormalizedLoaded

返回值

  • v1.1.0 及以上版本

    () => void

  • v1.1.0 以下版本

    void

说明

v1.1.0 及以上版本返回用来移除自身的函数。

beforeEach

  • beforeEach(guard): () => void

路由跳转前的守卫。

参数

名称 类型 描述
guard NavigationGuardWithThis 要加入的导航钩子

返回值

  • v1.1.0 及以上版本

    () => void

  • v1.1.0 以下版本

    void

说明

v1.1.0 及以上版本返回用来移除自身的函数。

removeBeforeEach

  • removeBeforeEach(): () => void

移除全局的 beforeEach 路由跳转前的守卫。

返回值

void

updateRoute

  • updateRoute(routeRecord): () => void

动态更新routes配置中的路由信息。

参数

名称 类型 描述
routeRecord RouteRecordNormalized 增加的路由信息

返回值

void

hasRoute

  • hasRoute(path): () => boolean

判断路由是否存在。根据 getCurrentPages 返回的当前路由栈信息判断,和routes中的无关。

参数

名称 类型 描述
path string 页面地址

返回值

boolean

说明

v1.1.0 及以上版本支持通过路由名称 name 判断
v1.1.0 及以上版本传页面地址时请去掉前面的 /,示例:pages/index/index

getRoutes

获取所有的路由信息。根据 getCurrentPages 返回的当前路由栈信息判断,和routes的信息无关。

说明

v1.1.0 及以上版本可以获取 routes 中配置的内容,以符合规范化路由信息标准

back

  • back(delta): () => void

关闭当前页面,返回上一页面或多级页面。同 uni.navigateBack

参数

名称 类型 描述
delta number 返回的页面数,如果 delta 大于现有页面数,则返回到首页

from

获取即将离开的路由信息。

说明

v1.1.0 及以上版本该方法被废弃,由 from 属性替代。

push

  • v1.1.0 及以上版本

    • push(to): Promise<NavigationFailure | null>

      程序式地通过将一条记录加入到历史栈中来导航到一个新的 URL。

      参数

      名称 类型 描述
      to RouteRecordPath 要导航到的路由地址
      to RouteRecordNormalized 要导航到的路由信息

      返回值

      Promise<NavigationFailure | null>

  • v1.1.0 以下版本

    • push(to, options): () => void

      跳转到新的路由页面。

      参数

      名称 类型 描述
      to string 页面地址
      options RouteLocationRaw 可选配置项

      返回值

      void

replace

  • replace(to): Promise<NavigationFailure | null>

    程序式地通过替换历史栈中的当前记录来导航到一个新的 URL。

    参数

    名称 类型 描述
    to RouteRecordPath 要导航到的路由地址
    to RouteRecordNormalized 要导航到的路由信息

    返回值

    Promise<NavigationFailure | null>

    说明

    v1.1.0 及以上版本支持

reLaunch

  • reLaunch(to): Promise<NavigationFailure | null>

    关闭所有页面,打开到应用内的某个页面。

    参数

    名称 类型 描述
    to RouteRecordPath 要导航到的路由地址
    to RouteRecordNormalized 要导航到的路由信息

    返回值

    Promise<NavigationFailure | null>

    说明

    v1.1.0 及以上版本支持

switchTab

  • switchTab(to): Promise<NavigationFailure | null>

    跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面。

    参数

    名称 类型 描述
    to RouteRecordPath 要导航到的路由地址
    to RouteRecordNormalized 要导航到的路由信息

    返回值

    Promise<NavigationFailure | null>

    说明

    v1.1.0 及以上版本支持

onError

  • onError(handler: ErrorListener): void

    添加一个错误处理器,它会在每次导航遇到未被捕获的错误出现时被调用。其中包括同步和异步被抛出的错误、在任何导航守卫中返回或传入 next 的错误、尝试解析一个需要渲染路由的异步组件时发生的错误。

    参数

    名称 类型 描述
    handler ErrorListener 要注册的错误处理器

    返回值

    void

    说明

    v1.1.0 及以上版本支持

resolve

  • resolve(to: RouteRecordName): RouteLocationNormalizedLoaded | null

    返回一个路由的规范化路由信息。

    参数

    名称 类型 描述
    to RouteRecordName 路由名称

    返回值

    RouteLocationNormalizedLoaded | null

    说明

    v1.1.0 及以上版本支持

useRouter

返回当前路由器实例。

useRoute

返回当前路由信息。

自定义类型

RouteRecordRedirect

export type RouteRecordRedirect = {
    path?: string;
    name?: string;
};

RouteRecordName

import * as PagesJson from '@/pagesJsonRouter.uts';

/**
 * 路由名称
 */
export type RouteRecordName = PagesJson.PageName

提示

v1.1.0 及以上版本支持

RouteRecordPath

import * as PagesJson from '@/pagesJsonRouter.uts';

/**
 * 路由地址
 */
export type RouteRecordPath = PagesJson.PagePath

提示

v1.1.0 及以上版本支持

RouteLocationGuardReturnOptions

export type RouteLocationGuardReturnOptions = {
    /**
     * 当前路由的 `query` 传参
     */
    query?: UTSJSONObject
    // params?: Map<string, any>
    /**
     * 当前路由去除 `query` 参数后的页面地址
     */
    path?: string
    /**
     * 当前路由隐式传参,即参数不在地址栏中展现
     * + `v1.1.0` 及以上版本支持。
     */
    data?: UTSJSONObject
    /**
     * 路由名称,即 `routes` 中配置的 `name` 参数
     */
    name?: RouteRecordName
    /**
     * 路由元信息,即 `routes` 中配置的 `meta` 参数
     */
    meta?: UTSJSONObject
    /**
     * 当前路由页面带参数的完整地址,如:`/pages/user/info?id=1`
     * + `v1.1.0` 及以上版本支持。
     */
    fullPath?: string
};

NavigationGuardReturn

export type NavigationGuardReturn = {
    /**
     * 即将前往的路由信息
     */
    to?: RouteLocationGuardReturnOptions
    /**
     * 当前路由信息
     */
    from?: RouteLocationGuardReturnOptions
};

RouteLocationNormalizedLoaded

/**
 * 导航完成后的规范化路由信息
 */
export type RouteLocationNormalizedLoaded = {
    /**
     * 当前路由的 `query` 传参
     */
    query?: UTSJSONObject
    /**
     * @deprecated 该属性即将被废弃,请用 `data` 替代
     */
    params?: UTSJSONObject
    /**
     * 路由隐式传参,即路由参数不在地址栏中展现的参数,用来替代旧版本的 `params`
     * + `v1.1.0` 及以上版本支持
     */
    data?: UTSJSONObject
    /**
     * 路由名称
     * + `v1.1.0` 及以上版本支持,即 `routes` 中的 `name` 参数
     */
    name?: RouteRecordName
    /**
     * 当前路由页面地址,这个是去除参数后的地址,如:`/pages/user/info`
     */
    path: string
    /**
     * @deprecated 该属性即将被废弃,请用 `fullPath` 替代
     */
    fullUrl?: string
    /**
     * 该属性替代旧版本的 `fullUrl`
     */
    fullPath?: string
    /**
     * 路由元信息,即 `routes` 中的 `meta` 参数
     */
    meta?: UTSJSONObject
    /**
     * 从哪个页面跳转过来的
     */
    from?: RouteLocationNormalizedLoaded
    /**
     * 要到哪个页面去,一般用于路由拦截后完成某些操作再重定向到目标页面的场景
     */
    to?: RouteLocationNormalizedLoaded
};

NavigationGuardWithThis

export type NavigationGuardWithThis = (to: RouteLocationNormalizedLoaded | null, from: RouteLocationNormalizedLoaded | null) => Promise<any | null>

RouteRecordRedirectOption

export type RouteRecordRedirectOption = (to: RouteLocationNormalizedLoaded) => RouteRecordNormalized | null

提示

v1.1.0 及以上版本支持。

RouteRecordNormalized

/**
 * 创建路由时路由表中的路由信息
 */
export type RouteRecordNormalized = {
    /**
     * 被注册的 `beforeEnter` 前置守卫
     */
    beforeEnter?: NavigationGuardWithThis
    // children: any[]
    /**
     * 路由元信息
     */
    meta?: UTSJSONObject
    /**
     * 路由名称
     */
    name?: RouteRecordName
    /**
     * 当前路由页面地址,这个是去除参数后的地址,如:`/pages/user/info`
     */
    path?: PagesJson.PagePath
    /**
     * 当前路由的 `query` 传参
     */
    query?: UTSJSONObject
    /**
     * 路由隐式传参,替代旧版本的 `params`
     */
    data?: UTSJSONObject
    /**
     * 被注册的路由重定向守卫
     */
    redirect?: RouteRecordRedirectOption
    /**
     * 是否开启启动拦截,开启后 `beforeEnter` 和 `redirect` 会在实例加载成功后就立刻挂载全局,适用于应用启动拦截的场景,如首页未登录直接跳转登录页等。
     */
    startupIntercept?: boolean
    /**
     * 窗口显示的动画类型,`v1.1.0` 及以上版本支持
     * + auto: 自动选择动画效果
     * + none: 无动画效果
     * + slide-in-right: 从右侧横向滑动效果
     * + slide-in-left: 左侧横向滑动效果
     * + slide-in-top: 从上侧竖向滑动效果
     * + slide-in-bottom: 从下侧竖向滑动效果
     * + fade-in: 从透明到不透明逐渐显示效果
     * + zoom-out: 从小到大逐渐放大显示效果
     * + zoom-fade-out: 从小到大逐渐放大并且从透明到不透明逐渐显示效果
     * + pop-in: 从右侧平移入栈动画效果
     */
    animationType?: string
    /**
     * 窗口显示动画的持续时间,单位为 ms
     * + `v1.1.0` 及以上版本支持
     */
    animationDuration?: number
}

RouterOptions

  • v1.1.0 及以上版本

    /**
     * 创建路由器的配置参数
     */
    export type RouterOptions = {
        /**
         * 创建路由器时的初始化路由表
         */
        routes: RouteRecordNormalized[]
    }
  • v1.1.0 以下版本

    export type RouterOptions = {
        routes: RouteRecordNormalized[];
        parseQuery?: (url: string) => UTSJSONObject;
        stringifyQuery?: (query: UTSJSONObject) => string;
        debug?: boolean;
    };

NavigationFailureType

/**
 * 导航失败类型
 * + aborted 被中止,比如路由守卫中手动返回了 `false`
 * + cancelled 被取消,比如下一个导航已经开始而导航失败
 * + duplicated 重复导航,比如现在已经处于要导航到的路径而导航失败
 */
export type NavigationFailureType = 
| 'aborted'
| 'cancelled'
| 'duplicated'

提示

v1.1.0 及以上版本支持

RouteLocationRaw

export type RouteLocationRaw = {
    query: any;
};

NavigationFailure

/**
 * 导航失败信息
 * + from 当前路由信息
 * + to 即将前往的路由信息
 * + type 导航失败类型
 */
export type NavigationFailure = {
    from: RouteLocationNormalizedLoaded
    to: RouteLocationNormalizedLoaded,
    type?: NavigationFailureType
}

提示

v1.1.0 及以上版本支持

NavigationHookAfter

  • v1.1.0 及以上版本

    export type NavigationHookAfter = (to: RouteLocationNormalizedLoaded, from: RouteLocationNormalizedLoaded, failure: NavigationFailure | null) => any
  • v1.1.0 以下版本

    export type NavigationHookAfter = (to: RouteLocationNormalizedLoaded, from: RouteLocationNormalizedLoaded) => void;

ErrorListener

/**
 * `onError` 回调定义
 */
export type ErrorListener = (error: any) => void

提示

v1.1.0 及以上版本支持

Page

该类型定义是因为 v1.0.2 版本前 getCurrentPages 返回的 Page 类型无法直接在web使用,暂时只能自己定义类型规避web上的问题

export type Page = {
    route: string;
    options: Map<string, string | null>
};

说明

v1.0.2 及以上版本该类型已废弃,使用官方的 Page

相关类和函数签名定义

/**
 * 路由实例管理
 *  `v1.1.0` 及以上版本已废弃,由interface替代
 */
export declare class KuxRouter {
    /**
     * 当前路由表信息
     */
    public _routes: RouteLocationNormalizedLoaded[];
    /**
     * 即将前往的路由信息
     */
    public _to: RouteLocationNormalizedLoaded;

    constructor();

    /**
     * 当前路由信息
     * @returns {RouteLocationNormalizedLoaded}
     */
    public currentRoute(): RouteLocationNormalizedLoaded;

    /**
     * 路由跳转后的守卫
     * @description 路由跳转后执行的导航守卫钩子,全局都会生效
     * @param {RouteLocationNormalizedLoaded} to 即将访问的路由信息
     * @param {RouteLocationNormalizedLoaded} from 即将离开的路由信息
     */
    public afterEach(callback: (to: RouteLocationNormalizedLoaded, from: RouteLocationNormalizedLoaded) => void): void;

    /**
     * 路由跳转前的守卫
     * @description 路由跳转前执行的导航守卫钩子,全局都会生效
     * @param {RouteLocationNormalizedLoaded} to 即将访问的路由信息
     * @param {RouteLocationNormalizedLoaded} from 即将离开的路由信息
     */
    public beforeEach(callback: (to: RouteLocationNormalizedLoaded, from: RouteLocationNormalizedLoaded) => Promise<NavigationGuardReturn>): void;

    /**
     * 移除全局的 `beforeEach` 路由跳转前的守卫
     */
    public removeBeforeEach(): void;

    /**
     * 动态增加routes配置中的路由信息
     * @param {RouteRecordNormalized} routeRecord 增加的路由信息
     */
    public addRoute(routeRecord: RouteRecordNormalized): void;

    /**
     * 动态更新routes配置中的路由信息
     * @param {RouteRecordNormalized} routeRecord 增加的路由信息
     */
    public updateRoute(routeRecord: RouteRecordNormalized): void;

    /**
     * 判断路由是否存在
     * @description 根据getCurrentPages返回的当前路由栈信息判断,和routes中的无关
     * @param {string} path 页面地址
     * @returns {boolean}
     */
    public hasRoute(path: string): boolean;

    /**
     * 获取所有的路由信息
     * @description 根据 `getCurrentPages` 返回的当前路由栈信息判断,和routes的信息无关
     * @returns {RouteLocationNormalizedLoaded[]}
     */
    public getRoutes(): RouteLocationNormalizedLoaded[];

    /**
     * 关闭当前页面,返回上一页面或多级页面
     * @param {number} delta 返回的页面数,如果 `delta` 大于现有页面数,则返回到首页
     */
    public back(delta?: number): void;

    /**
     * 获取即将离开的路由信息
     * @returns {RouteLocationNormalizedLoaded}
     */
    public from(): RouteLocationNormalizedLoaded;

    /**
     * 跳转到新的路由页面
     * @param {string} to 页面地址
     * @param {RouteLocationRaw} options 可选配置项
     */
    public push(to: string, options?: RouteLocationRaw): Promise<void>;
}

/**
 * 定义一个路由器实例接口
 *  `v1.1.0` 及以上版本支持
 */
export interface IRouter {
    /**
     * 当前的 `RouteLocationNormalized`
     */
    // readonly currentRoute: Ref<RouteLocationNormalizedLoaded | null>

    /**
     * 创建路由器时的原始选项对象。
     * + `v1.1.0` 及以上版本支持
     */
    readonly options: RouterOptions | null

    /**
     * 获取即将离开的路由信息。
     * + `v1.1.0` 及以上版本支持
     */
    from: RouteLocationNormalizedLoaded | null

    /**
     * 动态增加 routes 配置中的路由信息。
     * @param { RouteRecordNormalized } route `routes` 中的路由配置信息。
     * @deprecated 该方法即将被废弃,由路由库提供新的自动化解决方案替代。
     */
    addRoute (route: RouteRecordNormalized): Promise<any | null>

    /**
     * 动态更新 `routes` 配置中的路由信息。
     * @param { RouteRecordNormalized } route `routes` 中的路由配置信息。
     */
    updateRoute (route: RouteRecordNormalized): Promise<any | null>

    /**
     * 获取当前路由信息
     * @returns 返回一个规范化的路由信息。
     */
    currentRoute (): RouteLocationNormalizedLoaded

    /**
     * 添加一个导航钩子,它会在每次导航之后被执行。返回一个用来移除该钩子的函数。
     * @param { NavigationHookAfter } guard 要加入的导航钩子
     */
    afterEach (guard: NavigationHookAfter): () => void

    /**
     * 用来移除所有的 `afterEach` 钩子函数
     */
    removeAfterEach (): void

    /**
     * 通过调用 uni.navigateBack() 在可能的情况下在历史中后退。相当于 router.go(-1)。
     * @param { number } delta 回退的页面数,如果 delta 大于现有页面数,则返回到首页
     */
    back (delta?: number): void

    /**
     * 通过调用 uni.navigateBack() 在可能的情况下在历史中后退。相当于 router.go(-1)。
     * @param { number } delta 回退的页面数,如果 delta 大于现有页面数,则返回到首页
     * @param { RouteLocationNormalizedOptions } options 路由跳转时的配置参数,比如跳转时的转场动画配置
     */
    back (delta?: number, options?: RouteLocationNormalizedOptions): void

    /**
     * 添加一个导航钩子,它会在每次导航之前被执行。返回一个用来移除该钩子的函数。
     * @param { NavigationGuardWithThis } guard 要加入的导航钩子
     */
    beforeEach (guard: NavigationGuardWithThis): () => void

    /**
     * 用来移除所有的 `beforeEach` 守卫。
     * + `v1.1.0` 及以上版本支持。
     */
    removeBeforeEach (): void

    /**
     * 添加一个导航守卫,它会在导航将要被解析之前被执行。此时所有组件都已经获取完毕,且其它导航守卫也都已经完成调用。返回一个用来移除该守卫的函数。
     * @param { NavigationGuardWithThis } guard 要加入的导航钩子
     */
    // beforeResolve (guard: NavigationGuardWithThis): () => void

    /**
     * 通过调用 history.forward() 在可能的情况下在历史中前进。相当于 router.go(1)。
     */
    // forward (): void

    /**
     * 获得所有路由记录的完整列表。
     * @returns { RouteRecordNormalized[] } 返回所有路由记录的完整列表。
     */
    getRoutes (): RouteRecordNormalized[]

    // go (delta: number): void

    /**
     * 检查一个给定名称的路由是否存在。
     * @param { string } name 要检查的路由名称
     */
    hasRoute (name: string): boolean

    /**
     * 添加一个错误处理器,它会在每次导航遇到未被捕获的错误出现时被调用。其中包括同步和异步被抛出的错误、在任何导航守卫中返回或传入 next 的错误、尝试解析一个需要渲染路由的异步组件时发生的错误。
     * + `v1.1.0` 及以上版本支持。
     * @param { ErrorListener } handler 要注册的错误处理器
     */
    onError (handler: ErrorListener): void

    /**
     * 程序式地通过将一条记录加入到历史栈中来导航到一个新的 URL。
     * @param { RouteRecordPath } to 要导航到的路由地址
     */
    push (to: RouteRecordPath): Promise<NavigationFailure | null>

    /**
     * 程序式地通过将一条记录加入到历史栈中来导航到一个新的 URL。
     * @param { RouteRecordNormalized } to 要导航到的路由信息
     */
    push (to: RouteRecordNormalized): Promise<NavigationFailure | null>

    /**
     * 程序式地通过将一条记录加入到历史栈中来导航到一个新的 URL。
     * @param { any } to 要导航到的路由信息
     * @param { RouteLocationNormalizedOptions } options 路由跳转时的配置参数,比如跳转时的转场动画配置
     */
    push (to: any): Promise<NavigationFailure | null>

    // removeRoute (name: RouteRecordName): void

    /**
     * 程序式地通过替换历史栈中的当前记录来导航到一个新的 URL。
     * + `v1.1.0` 及以上版本支持。
     * @param { RouteRecordPath } to 要导航到的路由地址
     */
    replace (to: RouteRecordPath): Promise<NavigationFailure | null>

    /**
     * 程序式地通过替换历史栈中的当前记录来导航到一个新的 URL。
     * + `v1.1.0` 及以上版本支持。
     * @param { RouteRecordNormalized } to 要导航到的路由信息
     */
    replace (to: RouteRecordNormalized): Promise<NavigationFailure | null>

    /**
     * 程序式地通过替换历史栈中的当前记录来导航到一个新的 URL。
     * + `v1.1.0` 及以上版本支持。
     * @param { any } to 要导航到的路由信息
     */
    replace (to: any): Promise<NavigationFailure | null>

    /**
     * 关闭所有页面,打开到应用内的某个页面
     * `v1.1.0` 及以上版本支持
     * @param { RouteRecordPath } to 要导航到的路由地址
     */
    reLaunch (to: RouteRecordPath): Promise<NavigationFailure | null>

    /**
     * 关闭所有页面,打开到应用内的某个页面
     * `v1.1.0` 及以上版本支持
     * @param { RouteRecordNormalized } to 要导航到的路由信息
     */
    reLaunch (to: RouteRecordNormalized): Promise<NavigationFailure | null>

    /**
     * 关闭所有页面,打开到应用内的某个页面
     * `v1.1.0` 及以上版本支持
     * @param { any } to 要导航到的路由信息
     */
    reLaunch (to: any): Promise<NavigationFailure | null>

    /**
     * 跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面
     * `v1.1.0` 及以上版本支持
     * @param { RouteRecordPath } to 要导航到的路由地址
     */
    switchTab (to: RouteRecordPath): Promise<NavigationFailure | null>

    /**
     * 跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面
     * `v1.1.0` 及以上版本支持
     * @param { RouteRecordNormalized } to 要导航到的路由信息
     */
    switchTab (to: RouteRecordNormalized): Promise<NavigationFailure | null>

    /**
     * 跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面
     * @param { any } to 要导航到的路由信息
     */
    switchTab (to: any): Promise<NavigationFailure | null>

    /**
     * 返回一个路由地址的规范化路由信息。
     * + `v1.1.0` 及以上版本支持。
     * @param { RouteRecordName } to 路由地址
     * @returns { RouteLocationNormalizedLoaded } 返回规范化的路由信息
     */
    resolve (to: RouteRecordName): RouteLocationNormalizedLoaded | null
}

/**
 * 定义一个管理路由实例接口
 *  `v1.1.0` 及以上版本支持
 */
export interface IRoute {
    /**
     * 获取当前所有路由信息
     * @returns 返回当前所有路由的规范化路由信息列表
     */
    getRoutes (): RouteLocationNormalizedLoaded[];

    /**
     * 获取当前路由信息
     * @returns 返回当前路由的规范化路由信息
     */
    current (): RouteLocationNormalizedLoaded;

    /**
     * 根据路由地址判断该路由是否存在
     * @param { string } path 要判断的路由地址
     */
    hasRoute (path: string): boolean;

    /**
     * 返回一个路由地址的规范化路由信息。
     * + `v1.1.0` 及以上版本支持。
     * @param { RouteRecordName } to 路由地址
     * @returns { RouteLocationNormalizedLoaded } 返回规范化的路由信息
     */
    resolve (to: RouteRecordName): RouteLocationNormalizedLoaded | null;
}

/**
 * 返回当前路由器实例
 *  `v1.1.0` 以下版本
 */
export declare function useRouter (): KuxRouter;

// v1.1.0 及以上版本
export declare function useRouter (): IRouter

/**
 * 返回当前路由信息
 */
 // v1.1.0 以下版本
export declare function useRoute (): RouteLocationNormalizedLoaded;

// v1.1.0 及以上版本
export declare function useRoute (): RouteLocationNormalizedLoaded

/**
 * 创建一个路由器实例
 */
 // v1.1.0 以下版本
export declare function createRouter(options?: RouterOptions): KuxRouter;

// v1.1.0 及以上版本
export declare function createRouter (options: RouterOptions): IRouter

说明

HBuilderX 版本 4.0 及以上才支持。


结语

kux 不生产代码,只做代码的搬运工,致力于提供uts 的 js 生态轮子实现,欢迎各位大佬在插件市场搜索使用 kux 生态插件:https://ext.dcloud.net.cn/search?q=kux


友情推荐

  • TMUI4.0:包含了核心的uts插件基类.和uvue组件库
  • GVIM即时通讯模版:GVIM即时通讯模版,基于uni-app x开发的一款即时通讯模版
  • t-uvue-ui:T-UVUE-UI是基于UNI-APP X开发的前端UI框架
  • UxFrame 低代码高性能UI框架:【F2图表、双滑块slider、炫酷效果tabbar、拖拽排序、日历拖拽选择、签名...】UniAppX 高质量UI库
  • wx-ui 基于uni-app x开发的高性能混合UI库:基于uni-app x开发的高性能混合UI库,集成 uts api 和 uts component,提供了一套完整、高效且易于使用的UI组件和API,让您以更少的时间成本,轻松完成高性能应用开发。
  • firstui-uvue:FirstUI(unix)组件库,一款适配 uni-app x 的轻量、简洁、高效、全面的移动端组件库。
  • easyXUI 不仅仅是UI 更是为UniApp X设计的电商模板库:easyX 不仅仅是UI库,更是一个轻量、可定制的UniAPP X电商业务模板库,可作为官方组件库的补充,始终坚持简单好用、易上手

隐私、权限声明

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

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

插件不采集任何数据

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

许可协议

MIT协议

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