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 相关文章推荐
ie focus bug 解决方法
Sep 03 Javascript
取选中的radio的值
Jan 11 Javascript
javascript算法学习(直接插入排序)
Apr 12 Javascript
浅谈js的setInterval事件
Dec 05 Javascript
Underscore.js常用方法总结
Feb 28 Javascript
如何使用jQuery技术开发ios风格的页面导航菜单
Jul 29 Javascript
jQuery实现的简洁下拉菜单导航效果代码
Aug 26 Javascript
浅谈通过JS拦截 pushState和replaceState事件
Jul 21 Javascript
微信小程序支付之c#后台实现方法
Oct 19 Javascript
vue+webpack实现异步加载三种用法示例详解
Apr 24 Javascript
100行代码实现vue表单校验功能(小白自编)
Nov 19 Javascript
微信小程序后端实现授权登录
Feb 24 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
PHP json格式和js json格式 js跨域调用实现代码
2012/09/08 PHP
PHP判断文章里是否有图片的简单方法
2014/07/26 PHP
PHP利用超级全局变量$_GET来接收表单数据的实例
2016/11/05 PHP
php5.5使用PHPMailer-5.2发送邮件的完整步骤
2018/10/14 PHP
图片自动更新(说明)
2006/10/02 Javascript
在JavaScript中获取请求的URL参数
2010/12/22 Javascript
Javascript动态绑定事件的简单实现代码
2010/12/25 Javascript
40款非常有用的 jQuery 插件推荐(系列一)
2011/12/21 Javascript
jQuery中选择器小问题(新人难免遇到)
2014/03/31 Javascript
关于img的href和src取变量及赋值的方法
2014/04/28 Javascript
window.open()详解及浏览器兼容性问题示例探讨
2014/05/29 Javascript
JavaScript跨域方法汇总
2014/10/16 Javascript
EasyUI实现第二层弹出框的方法
2015/03/01 Javascript
Python脚本后台运行的几种方式
2015/03/09 Javascript
JavaScript Window浏览器对象模型方法与属性汇总
2015/04/20 Javascript
JavaScript数据库TaffyDB用法实例分析
2015/07/27 Javascript
浅谈JavaScript中小数和大整数的精度丢失
2016/05/31 Javascript
JavaScript对Json的增删改属性详解
2016/06/02 Javascript
Angular的模块化(代码分享)
2016/12/26 Javascript
bootstrap 表单验证使用方法
2017/01/11 Javascript
JavaScript脚本语言是什么_动力节点Java学院整理
2017/06/26 Javascript
微信浏览器禁止页面下拉查看网址实例详解
2017/06/28 Javascript
通过button将form表单的数据提交到action层的实例
2017/09/08 Javascript
轻量级JS Cookie插件js-cookie的使用方法
2018/03/22 Javascript
Vue作用域插槽slot-scope实例代码
2018/09/05 Javascript
React注册倒计时功能的实现
2018/09/06 Javascript
Python实现一个简单的MySQL类
2015/01/07 Python
在Python中使用CasperJS获取JS渲染生成的HTML内容的教程
2015/04/09 Python
Python爬虫之模拟知乎登录的方法教程
2017/05/25 Python
在Python web中实现验证码图片代码分享
2017/11/09 Python
微信跳一跳小游戏python脚本
2018/01/05 Python
python psutil库安装教程
2018/03/19 Python
Pycharm创建项目时如何自动添加头部信息
2019/11/14 Python
python 通过邮件控制实现远程控制电脑操作
2020/03/16 Python
机械设计及其自动化求职推荐信
2014/02/17 职场文书
自动在Windows中运行Python脚本并定时触发功能实现
2021/09/04 Python