admin管理员组文章数量:1133652
Ok, to explain this simply:
I have 3x pages.
- Page 1 (Home)
- Page 2 (Menu)
- Page 3 (About)
Page 1 has a-
<router-link to="/menu">
button that when clicked routes to "/menu".
For now, Page 2 (Menu) has a
<router-link to="/">
button and when this button is clicked it reverts to the previous location "/" Page 1 (Home).
But I don't want to create a component for router for each page to 'go back' to the previous page (as if I had 100 pages this could be a lot of work routing back). Is there a way to do this with vue-router? similar to window.history.back()
I'm curious to see if there is a way to do this as I can't find it in the docs.
Ok, to explain this simply:
I have 3x pages.
- Page 1 (Home)
- Page 2 (Menu)
- Page 3 (About)
Page 1 has a-
<router-link to="/menu">
button that when clicked routes to "/menu".
For now, Page 2 (Menu) has a
<router-link to="/">
button and when this button is clicked it reverts to the previous location "/" Page 1 (Home).
But I don't want to create a component for router for each page to 'go back' to the previous page (as if I had 100 pages this could be a lot of work routing back). Is there a way to do this with vue-router? similar to window.history.back()
I'm curious to see if there is a way to do this as I can't find it in the docs.
Share Improve this question edited Dec 18, 2022 at 22:46 starball 49.2k28 gold badges194 silver badges865 bronze badges asked Jan 4, 2018 at 23:03 John107John107 2,2775 gold badges22 silver badges39 bronze badges 3- 3 router.go(n) | Programmatic Navigation | vue-router – yuriy636 Commented Jan 4, 2018 at 23:08
- 1 @yuriy636's is probably the best answer. Currently we have and outer component with the back button which uses string manipulation on the current url to go back to the last page in the route. We will probably change to the router.go method when we get the chance now though – Kartik Prasad Commented Jan 4, 2018 at 23:11
- 1 Ok thanks! It was staring me right in the face! I'm not really sure how to write this into my syntax though. Sorry! I'm new to this! – John107 Commented Jan 4, 2018 at 23:15
8 Answers
Reset to default 300You can use Programmatic Navigation. In order to go back, you use this:
router.go(n)
Where n
can be positive or negative (to go back). This is the same as history.back()
.So you can have your element like this:
<a @click="$router.go(-1)">back</a>
Use $router.back()
directly to go back/route-back programmatic on vue-router. Or if in the template of the component use router.back()
.
This works like a clock for me:
methods: {
hasHistory () { return window.history.length > 2 }
}
Then, in the template:
<button
type="button"
@click="hasHistory()
? $router.go(-1)
: $router.push('/')" class="my-5 btn btn-outline-success">«
Back
</button>
Worked for me, short and practical. (Nuxt.js)
<a @click="$router.back()"></>
If you're using Vuex
you can use https://github.com/vuejs/vuex-router-sync
Just initialize it in your main file with:
import VuexRouterSync from 'vuex-router-sync';
VuexRouterSync.sync(store, router);
Each route change will update route
state object in Vuex
.
You can next create getter
to use the from
Object in route state or just use the state
(better is to use getters, but it's other story
https://vuex.vuejs.org/en/getters.html),
so in short it would be (inside components methods/values):
this.$store.state.route.from.fullPath
You can also just place it in <router-link>
component:
<router-link :to="{ path: $store.state.route.from.fullPath }">
Back
</router-link>
So when you use code above, link to previous path would be dynamically generated.
This answer to this question becomes much trickier if you're coding a mobile app as you now need an integrated solution that accommodates back history from either your UI back button OR the "back" button provided by the mobile device!
Frameworks like Ionic and Quasar can intercept mobile device back button events. Quasar handles these events for you and adapts behaviour for desktop and mobile platform builds so a for example a Cordova/Capacitor mobile app build will ensure that a "back" action can intelligently either close a dialog or go back a page or even close the app!
Quasar Back event handler and
v-go-back
directive- https://quasar.dev/vue-directives/go-back
Ionic - Back button and Hardware back button
- https://ionicframework.com/docs/api/back-button
- https://ionicframework.com/docs/developing/hardware-back-button
This might help someone
<router-link class="inner-back d-inline-block" to="">
<i class="fas fa-arrow-left" @click="$router.go(-1)"></i>
</router-link>
Another solution is using vue-router-back-mixin
import BackMixin from `vue-router-back-mixin`
export default {
...
mixins: [BackMixin],
methods() {
goBack() {
this.backMixin_handleBack()
}
}
...
}
本文标签: javascriptHow can I go backrouteback on vuerouterStack Overflow
版权声明:本文标题:javascript - How can I go backroute-back on vue-router? - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1736770453a1952055.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论