在vue中使用路由实现页面刷新
程序员文章站
2022-05-11 09:14:34
...
本篇文章主要介绍了vue通过路由实现页面刷新的方法,现在分享给大家,也给大家做个参考。
vue 开发微信商城项目,
需求如下:
购物车页面跳转到详情页,购物车页面包含了多个组件,点击结算跳转到订单页面,从订单返回时,购物车页面没有刷新,由于购物车组件之间通过bus实现事件传递,页面跳转(非物理返回)无法触发beforeDestroy方法,则无法再此方法中销毁bus方法
beforeDestroy() { this.$root.Bus.$off('judge') this.$root.Bus.$off('refreshDetail') this.$root.Bus.$off('clearAll') this.$root.Bus.$off('upDataCart') },
无奈,通过beforeRouteLeave来销毁
beforeRouteLeave(to, from, next) { this.$root.Bus.$off('judge') this.$root.Bus.$off('refreshDetail') this.$root.Bus.$off('clearAll') this.$root.Bus.$off('upDataCart') next() },
同样的,物理返回时无法触发购物车的created方法,则无法触发bus的$on方法
归根结底,物理返回时刷新页面则可以处理此问题
思路一
beforeRouteEnter(to, from, next) { next(()=>{ window.location.reload() }) },
此方法理论貌似可行,但是页面会狂刷不止,
最后采用了思路二,貌似是一个很low的方法,但是解决了实际问题
this.$router.replace({ name: 'cart' })// 处理返回刷新问题 this.$router.push({ path: '/order/order_sure', query: { sku: sku_str, cart: 'cart' } })
页面跳转前先通过路由replace到当前页,再跳转到订单页面,返回可以自动刷新了,这个方法并不理想,如果您有更好的方法,欢迎分享
有专门的方法处理此问题,在购物车页面,添加如下代码即可
// 销毁组件,返回刷新 deactivated() { this.$destroy() },
上面是我整理给大家的,希望今后会对大家有帮助。
相关文章:
以上就是在vue中使用路由实现页面刷新的详细内容,更多请关注其它相关文章!
推荐阅读
-
Vue2.0使用嵌套路由实现页面内容切换/公用一级菜单控制页面内容切换(推荐)
-
Vue实现远程获取路由与页面刷新导致404错误的解决
-
Vue中在新窗口打开页面及Vue-router的使用
-
在vue中使用[provide/inject]实现页面reload
-
angular2中router路由跳转navigate的使用与刷新页面问题详解
-
解决Vue使用mint-ui loadmore实现上拉加载与下拉刷新出现一个页面使用多个上拉加载后冲突问题
-
Vue实现远程获取路由与页面刷新导致404错误的解决
-
Vue使用Clipboard.JS在h5页面中复制内容实例详解
-
vue中实现点击按钮滚动到页面对应位置的方法(使用c3平滑属性实现)
-
vue router嵌套路由在history模式下刷新无法渲染页面问题的解决方法