vue单页缓存存在的问题及解决方案(小结)


Posted in Javascript onSeptember 25, 2018

1.css同名覆盖,解决方法:父组件加上scoped

<style lang="scss" scoped>
 @import './unbind.scss'
</style>

子组件同名样式加上deep

/deep/ .tabs-row {
  .items-wrp{
   padding-left: .34rem;
  }
  .item {
   margin:0 .12rem .16rem 0;
  }
 }

2.事件全局绑定

绑在window或document或body上的事件,切换到下一个页面同样会被触发,需要销毁,也防止内存泄漏,全局绑定的事件如果是公用组件慎用off().on(),因为可能引用的其他的组件全局绑定的事件被移除

destroyed:返回的时候会触发,防止返回到上一页时window上scroll被触发,官网上是推荐在beforeDestroy做事件移除或者新增DOM或移动DOM操作

deactivated:前进到新页面时会触发,防止进入下一页时window上scroll被触发

activated:被缓存的页面激活,即返回时被触发,created此时不会被触发,重新绑定事件

activated () {
  // 不直接绑定scroll,此处有限制
  this.bindEvent()
 },
 destroyed () {
  $(window).off('scroll', this.handleScrollFn)
 },
 deactivated () {
  $(window).off('scroll', this.handleScrollFn)
 },

3.音频续播

当音频在还在播放时,跳转到新的页面,此时音频仍在播放,解决方法:前进到新页面会触发deactivated钩子,此时暂停音频播放

deactivated () {
  // 前进时暂停音频播放
  this.pauseAudio()
 },
methods: {
  pauseAudio () {
   this.$refs.audioPlayer && this.$refs.audioPlayer.togglePlay()
  }
}

当音频在还在播放时,返回上一页,此时音频仍在播放,解决方法:返回会触发destroyed钩子里边关闭音频播放器

destroyed () {
  this.closeMini() //关闭音频播放器
 },
methods: {
  closeMini () {
   this.mode = -1
   this.play = false
   if (this.player) {
    this.player.pause()
   }
   this.$emit('callback', 'close')
  },
}

4.微信分享数据未更新

当返回上一页时,分享的数据没有更新,需要在激活的钩子里再次读取之前存的分享数据

activated () {
  // 单页缓存分享数据重置
  this.setShare(this.shareCache)
  window.addEventListener('scroll', this.finishReading)
 },
 methods: {
  setShare (opt) {
   if (!opt) return
   baike.setShare && baike.setShare(opt)
  //存该页的分享数据
   this.shareCache = opt 
  },
}

5.router.afterEach里上报pv时url未更新

在导航守卫afterEach里边上报,但是被触发时url还未更新,导致上报的参数有误,解决方法:通过to,from得到下一页,上一页的地址

var referrer = !from.name ? document.referrer :   
  `${location.origin}${from.fullPath}` // 通过from.name判断刷新

 var curUrl = `${location.origin}${to.fullPath}` || ''

6.hash改变时并不会触发router的守卫

代码中通过hash改变,监听hashchange来处理之后的逻辑,但是就不会触发router的导航守卫,也就是没有跳转,就不存在单页缓存

window.location.hash = '#refer'

解决办法:用replace替换url,相应的原来hashchange就不会监听到,需要把这块逻辑拿到created里边执行

this.$router.replace({path: `${location.pathname}${location.search}#refer`})

7.分享问题修复

单页缓存导致返回时分享的链接和自定义文案没有更新,针对特别处理的分享数据,在业务页面修改,解决方法

activated () {
  this.setShare(this.shareCache)
 },

 methods: {
  setShare (opt) {
   if (!opt) return
// xx.setShare封装的分享的底层方法
   xx.setShare && xx.setShare(opt)
   this.shareCache = opt
  }
}

针对普通分享页面,在router.afterEach里加 

router.afterEach((to, from) => {
 Vue.nextTick(() => {
  if (to.meta.notNeedShare) { //不需要分享的页面在路由配置文件里增加{meta: {notNeedShare:true}} 

if (window.WeixinJSBridge) {



 window.WeixinJSBridge.call('hideOptionMenu') 



} 


else { 



document.addEventListener('WeixinJSBridgeReady', () => { window.WeixinJSBridge.call('hideOptionMenu') })


 
}


}

 else { 


// 非分享自定义数据的页面处理 


 xx.setShare({ link: `${location.origin}${to.fullPath}` })
 }
 })
})

8.关注,收藏等toast提示在返回时未消失,因为延迟时间设置,解决方法:在路由钩子里边强制隐藏

router.afterEach((to, from) => {
 // 切换路由,有toast提示立刻隐藏
 xx.toast.hide()
})

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
用jquery仿做发微博功能示例
Apr 18 Javascript
javascript多行字符串的简单实现方式
May 04 Javascript
JSON字符串转JSON对象
Jul 31 Javascript
Bootstrap开发实战之第一次接触Bootstrap
Jun 02 Javascript
基于CSS3和jQuery实现跟随鼠标方位的Hover特效
Jul 25 Javascript
JS轮播图实现简单代码
Feb 19 Javascript
Vue封装Swiper实现图片轮播效果
Feb 06 Javascript
AjaxUpLoad.js实现文件上传功能
Mar 02 Javascript
详解多页应用 Webpack4 配置优化与踩坑记录
Oct 16 Javascript
微信小程序实现带缩略图轮播效果
Nov 04 Javascript
Vue父子组件传值的一些坑
Sep 16 Javascript
了不起的11个JavaScript代码重构最佳实践小结
Jan 11 Javascript
深入理解与使用keep-alive(配合router-view缓存整个路由页面)
Sep 25 #Javascript
使用vue2.0创建的项目的步骤方法
Sep 25 #Javascript
vue解决一个方法同时发送多个请求的问题
Sep 25 #Javascript
Vue2.0学习系列之项目上线的方法步骤(图文)
Sep 25 #Javascript
在vue中多次调用同一个定义全局变量的实例
Sep 25 #Javascript
vue观察模式浅析
Sep 25 #Javascript
详解搭建es6+devServer简单开发环境
Sep 25 #Javascript
You might like
松下Panasonic RF-B65电路分析
2021/03/02 无线电
laravel学习教程之关联模型
2016/07/30 PHP
PHP实现的链式队列结构示例
2017/09/15 PHP
checkbox全选/取消全选以及checkbox遍历jQuery实现代码
2009/12/02 Javascript
js操作textarea方法集合封装(兼容IE,firefox)
2011/02/22 Javascript
深入浅出理解javaScript原型链
2015/05/09 Javascript
node.js基于mongodb的搜索分页示例
2017/01/22 Javascript
jQuery中Chosen三级联动功能实例代码
2017/03/07 Javascript
Vue上传组件vue Simple Uploader的用法示例
2017/08/25 Javascript
详解设置Webstorm 利用babel将ES6自动转码成ES5
2017/12/20 Javascript
Angular实现的自定义模糊查询、排序及三角箭头标注功能示例
2017/12/28 Javascript
node.js中fs文件系统目录操作与文件信息操作
2018/02/24 Javascript
微信小程序实现基于三元运算验证手机号/姓名功能示例
2019/01/19 Javascript
Vue 事件处理操作实例详解
2019/03/05 Javascript
vue设置全局访问接口API地址操作
2020/08/14 Javascript
Python实例分享:快速查找出被挂马的文件
2014/06/08 Python
Python中的多重装饰器
2015/04/11 Python
python使用Queue在多个子进程间交换数据的方法
2015/04/18 Python
python实现从网络下载文件并获得文件大小及类型的方法
2015/04/28 Python
Python中处理字符串之isalpha()方法的使用
2015/05/18 Python
python爬虫之BeautifulSoup 使用select方法详解
2017/10/23 Python
Django如何自定义分页
2018/09/25 Python
python消费kafka数据批量插入到es的方法
2018/12/27 Python
python多任务及返回值的处理方法
2019/01/22 Python
pyqt5利用pyqtDesigner实现登录界面
2019/03/28 Python
Django 自定义分页器的实现代码
2019/11/24 Python
OpenCV哈里斯(Harris)角点检测的实现
2020/01/15 Python
HTML5+CSS3绘制锯齿状的矩形
2016/03/01 HTML / CSS
印尼穆斯林时尚购物网站:Hijabenka
2016/12/10 全球购物
蜜蜂引路教学反思
2014/02/04 职场文书
2014年乡镇党建工作总结
2014/11/11 职场文书
八一建军节慰问信
2015/02/14 职场文书
工程款申请报告
2015/05/15 职场文书
2015迎新晚会活动总结
2015/07/16 职场文书
创业计划书之校园超市
2019/09/12 职场文书
git stash(储藏)的用法总结
2022/06/25 Servers