Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/f-loat/mpvue-router-patch
🛴在 mpvue 中使用 vue-router 兼容的路由写法
https://github.com/f-loat/mpvue-router-patch
mpvue router vue
Last synced: 15 days ago
JSON representation
🛴在 mpvue 中使用 vue-router 兼容的路由写法
- Host: GitHub
- URL: https://github.com/f-loat/mpvue-router-patch
- Owner: F-loat
- License: mit
- Created: 2018-04-02T14:23:03.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2019-03-05T08:09:33.000Z (over 5 years ago)
- Last Synced: 2024-10-16T19:37:11.918Z (28 days ago)
- Topics: mpvue, router, vue
- Language: JavaScript
- Homepage:
- Size: 23.4 KB
- Stars: 300
- Watchers: 5
- Forks: 32
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# mpvue-router-patch
> 在 mpvue 中使用 vue-router 兼容的路由写法[![npm package](https://img.shields.io/npm/v/mpvue-router-patch.svg)](https://npmjs.org/package/mpvue-router-patch)
[![npm downloads](http://img.shields.io/npm/dm/mpvue-router-patch.svg)](https://npmjs.org/package/mpvue-router-patch)## 安装
``` bash
npm i mpvue-router-patch
```## 使用
``` js
// main.js
import Vue from 'vue'
import MpvueRouterPatch from 'mpvue-router-patch'Vue.use(MpvueRouterPatch)
```## API
> 支持以下列出的方法及属性
### Router 实例
#### 属性
* $router.app
当前页面的 Vue 实例
* $router.mode
路由使用的模式,固定值 `history`
* $router.currentRoute
当前路由对应的路由信息对象,等价于 $route
#### 方法
* $router.push(location, onComplete?, onAbort?, onSuccess?)
跳转到应用内的某个页面,`mpvue.navigateTo`、`mpvue.switchTab` 及 `mpvue.reLaunch` 均通过该方法实现,`location` 参数支持字符串及对象两种形式,跳转至 `tabBar` 页面或重启至某页面时必须以对象形式传入
``` js
// 字符串
router.push('/pages/news/detail')// 对象
router.push({ path: '/pages/news/detail' })// 带查询参数,变成 /pages/news/detail?id=1
router.push({ path: '/pages/news/detail', query: { id: 1 } })// 切换至 tabBar 页面
router.push({ path: '/pages/news/list', isTab: true })// 重启至某页面,无需指定是否为 tabBar 页面,但 tabBar 页面无法携带参数
router.push({ path: '/pages/news/list', reLaunch: true })
```* $router.replace(location, onComplete?, onAbort?, onSuccess?)
关闭当前页面,跳转到应用内的某个页面,相当于 `mpvue.redirectTo`,`location` 参数格式与 `$router.push` 相似,不支持 `isTab` 及 `reLaunch` 属性
* $router.go(n)
关闭当前页面,返回上一页面或多级页面,`n` 为回退层数,默认值为 `1`
* $router.back()
关闭当前页面,返回上一页面
### 路由信息对象
#### 属性
* $route.path
字符串,对应当前路由的路径,总是解析为绝对路径,如 `/pages/news/list`
* $route.params
空对象,小程序不支持该属性
* $route.query
一个 key/value 对象,表示 URL 查询参数。例如,对于路径 `/pages/news/detail?id=1`,则有 `$route.query.id == 1`,如果没有查询参数,则是个空对象。
* $route.hash
空字符串,小程序不支持该属性
* $route.fullPath
完成解析后的 URL,包含查询参数和 hash 的完整路径
* $route.name
当前路由的名称,由 `path` 转化而来