vue通过路由实现页面刷新的方法
2018-01-25 10:49
1276 查看
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() },
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- 解决element-ui中el-menu组件作为vue-router模式在刷新页面后default-active属性与当前路由页面不一致问题的方法
- vue 刷新之后 嵌套路由不变 重新渲染页面的方法
- vue 路由页面之间实现用手指进行滑动的方法
- vue.js实现刷新当前页面的方法教程
- vue通过 vue.mixin(混合)实现 任意页面记录滚动条位置(路由router.query参数一致) 并跳转到上次的位置
- Vue.js 通过jQuery ajax获取数据实现更新后重新渲染页面的方法
- ASP.NET页面刷新的实现方法(Zt)
- JS 实现页面刷新的多种方法
- 利用javascript实现web页面刷新的方法
- 实现页面定时刷新的三种方法(或者是两种吧)
- ASP.NET页面刷新的实现方法
- JS实现网页开窗刷新 GeT传递参数成功 远程打开页面失败的解决方法
- 先看看ASP.NET页面刷新的实现方法
- 使用jquery的load()方法实现页面局部刷新
- ASP.NET页面刷新的实现方法:
- [转]利用javascript实现web页面刷新的方法
- [JavaSricept]自动刷新页面的实现方法总结(转载--作者:郭昌华)
- ASP.NET 2.0 实现无刷新页面的一种方法(转)
- 通过js实现页面跳转的五种方法
- [转]自动刷新页面的实现方法总结