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 相关文章推荐
经典的带阴影的可拖动的浮动层
Jun 26 Javascript
按钮接受回车事件的三种实现方法
Jun 06 Javascript
jquery中获取元素里某一特定子元素的代码
Dec 02 Javascript
js实现仿爱微网两级导航菜单效果代码
Aug 31 Javascript
JavaScript的React框架中的JSX语法学习入门教程
Mar 05 Javascript
mvvm双向绑定机制的原理和实现代码(推荐)
Jun 07 Javascript
JavaScript将base64图片转换成formData并通过AJAX提交的实现方法
Oct 24 Javascript
vue-cli之router基本使用方法详解
Oct 17 Javascript
JavaScript内存泄漏的处理方式
Nov 20 Javascript
详解Webpack实战之构建 Electron 应用
Dec 25 Javascript
ExtJs使用自定义插件动态保存表头配置(隐藏或显示)
Sep 25 Javascript
vue配置接口域名方法总结
May 12 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_MySQL教程-第一天
2007/03/18 PHP
php中hashtable实现示例分享
2014/02/13 PHP
thinkphp连贯操作实例分析
2014/11/22 PHP
smarty模板引擎之配置文件数据和保留数据
2015/03/30 PHP
php合并数组并保留键值的实现方法
2018/03/12 PHP
用jquery设置按钮的disabled属性的实现代码
2010/11/28 Javascript
JavaScript中的prototype和constructor简明总结
2014/04/05 Javascript
jQuery+PHP打造滑动开关效果
2014/12/16 Javascript
JQuery中基础过滤选择器用法实例分析
2015/05/18 Javascript
基于Bootstrap+jQuery.validate实现表单验证
2016/05/30 Javascript
简单理解vue中实例属性vm.$els
2016/12/01 Javascript
JS实现简单拖拽效果
2017/06/21 Javascript
JavaScript输出所选择起始与结束日期的方法
2017/07/12 Javascript
JavaScript实现图片拖曳效果
2017/09/08 Javascript
基于Vuex无法观察到值变化的解决方法
2018/03/01 Javascript
JSON基本语法及与JavaScript的异同实例分析
2019/01/04 Javascript
vue微信分享的实现(在当前页面分享其他页面)
2019/04/16 Javascript
微信小程序scroll-view锚点链接滚动跳转功能
2019/12/12 Javascript
JavaScript实现简单进度条效果
2020/03/25 Javascript
零基础写python爬虫之神器正则表达式
2014/11/06 Python
Python最基本的输入输出详解
2015/04/25 Python
python、java等哪一门编程语言适合人工智能?
2017/11/13 Python
Django处理Ajax发送的Get请求代码详解
2019/07/29 Python
python实现ip地址查询经纬度定位详解
2019/08/30 Python
Django查询优化及ajax编码格式原理解析
2020/03/25 Python
python简单的三元一次方程求解实例
2020/04/02 Python
html5中的input新属性range使用记录
2014/09/05 HTML / CSS
英国标志性奢侈品牌:Burberry
2016/07/28 全球购物
俄罗斯三星品牌商店:GalaxyStore
2020/11/04 全球购物
团队精神演讲稿
2013/12/31 职场文书
关于赌博的检讨书
2014/01/24 职场文书
班组长安全工作职责
2014/07/15 职场文书
医院科室评语
2015/01/04 职场文书
部门优秀员工推荐信
2015/03/24 职场文书
python中%格式表达式实例用法
2021/06/18 Python
SpringDataJPA在Entity中常用的注解介绍
2021/12/06 Java/Android