require vue
2.x
and vue-router2.x
.
vue-navigation default behavior is similar to native mobile app (A、B、C are pages):
- A forward to B,then forward to C;
- C back to B,B will recover from cache;
- B back to A,A will recover from cache;
- A forward to B again,B will rebuild, not recover from cache.
!important: Because the browser does not provide page forward and backward events, so the library needs to maintain a routing record to determine the forward and backward behavior, so the current routing records are not allowed to contain duplicate routes, and now forward to the existing route will be identified as backward behavior
npm i -S vue-navigation
main.js
import Vue from 'vue'
import router from './router' // vue-router instance
import Navigation from 'vue-navigation'
Vue.use(Navigation, {router})
// bootstrap your app...
App.vue
<template>
<navigation>
<router-view></router-view>
</navigation>
</template>
functions: [ on
| once
| off
]
event types: [ forward
| back
| refresh
| reset
]
this.$navigation.on('forward', (from, to) => {})
this.$navigation.once('back', (from, to) => {})
this.$navigation.off('refresh', (current) => {})
this.$navigation.on('reset', () => {})
main.js
import Vue from 'vue'
import router from './router' // vue-router instance
import store from './store' // vuex store instance
import Navigation from 'vue-navigation'
Vue.use(Navigation, {router, store})
// bootstrap your app...
After passing in store
, vue-navigation
will register a module in store
(default module name is navigation
), and commit navigation/FORWARD
or navigation/BACK
or navigation/REFRESH
when the page jumps.
You can set the name of the module yourself:
Vue.use(Navigation, {router, store, moduleName: 'name'})
Use Vue.navigation
in global environment or use this.$navigation
in vue instance
getRoutes()
get the routing recordscleanRoutes()
clean the routing records