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 相关文章推荐
JS 页面内容搜索,类似于 Ctrl+F功能的实现代码
Aug 13 Javascript
Jquery 表格合并的问题分享
Sep 17 Javascript
公共js在页面底部加载的注意事项介绍
Jul 18 Javascript
JS封装的选项卡TAB切换效果示例
Sep 20 Javascript
bootstrap导航、选项卡实现代码
Dec 28 Javascript
对Vue2 自定义全局指令Vue.directive和指令的生命周期介绍
Aug 30 Javascript
layui form.render('select', 'test2') 更新渲染的方法
Sep 27 Javascript
Vue路由的模块自动化与统一加载实现
Jun 05 Javascript
vue 使用原生组件上传图片的实例
Sep 08 Javascript
js canvas实现俄罗斯方块
Oct 11 Javascript
Echarts在Taro微信小程序开发中的踩坑记录
Nov 09 Javascript
Vue多选列表组件深入详解
Mar 02 Vue.js
深入理解与使用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
wiki-shan写的php在线加密的解密程序
2008/09/07 PHP
php使用pclzip类实现文件压缩的方法(附pclzip类下载地址)
2016/04/30 PHP
PHP正则匹配日期和时间(时间戳转换)的实例代码
2016/12/14 PHP
详解如何在云服务器上部署Laravel
2017/06/30 PHP
thinkphp5使用无限极分类
2019/02/18 PHP
在laravel5.2中实现点击用户头像更改头像的方法
2019/10/14 PHP
js 实现 input type=&quot;file&quot; 文件上传示例代码
2013/08/07 Javascript
纯js简单日历实现代码
2013/10/05 Javascript
JQuery处理json与ajax返回JSON实例代码
2014/01/03 Javascript
JavaScript中Function()函数的使用教程
2015/06/04 Javascript
全面了解构造函数继承关键apply call
2016/07/26 Javascript
微信小程序 欢迎界面开发的实例详解
2016/11/30 Javascript
jQuery实现级联下拉框实战(5)
2017/02/08 Javascript
微信小程序实现登录页云层漂浮的动画效果
2017/05/05 Javascript
10行原生JS实现文字无缝滚动(超简单)
2018/01/02 Javascript
vue项目中用cdn优化的方法
2018/01/03 Javascript
vue的传参方式汇总和router使用技巧
2018/05/22 Javascript
JavaScript类数组对象转换为数组对象的方法实例分析
2018/07/24 Javascript
在Layui 的表格模板中,实现layer父页面和子页面传值交互的方法
2019/09/10 Javascript
vue 图片裁剪上传组件的实现
2020/11/12 Javascript
vue 中this.$set 动态绑定数据的案例讲解
2021/01/29 Vue.js
用Javascript实现发送短信验证码间隔功能
2021/02/08 Javascript
python实现爬虫下载漫画示例
2014/02/16 Python
Python的“二维”字典 (two-dimension dictionary)定义与实现方法
2016/04/27 Python
django 修改server端口号的方法
2018/05/14 Python
python多环境切换及pyenv使用过程详解
2019/09/27 Python
详解python常用命令行选项与环境变量
2020/02/20 Python
Python使用sqlite3模块内置数据库
2020/05/07 Python
django有哪些好处和优点
2020/09/01 Python
python爬虫构建代理ip池抓取数据库的示例代码
2020/09/22 Python
Django2.1.7 查询数据返回json格式的实现
2020/12/29 Python
Python页面加载的等待方式总结
2021/02/28 Python
大学生应聘求职信
2014/05/26 职场文书
工程安全生产协议书
2014/11/21 职场文书
丧事答谢词大全
2015/09/30 职场文书
《半截蜡烛》教学反思
2016/02/19 职场文书