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 学习笔记 选择器之一
Jul 23 Javascript
JQuery.closest(),parent(),parents()寻找父结点
Feb 17 Javascript
js 程序执行与顺序实现详解
May 13 Javascript
jQuery JSON实现无刷新三级联动实例探讨
May 28 Javascript
JavaScript通过字符串调用函数的实现方法
Mar 18 Javascript
JavaScript中指定函数名称的相关方法
Jun 04 Javascript
jQuery实现HTML表格单元格的合并功能
Apr 06 Javascript
javascript删除html标签函数cIsHTML
Jan 09 Javascript
AngularJS Select(选择框)使用详解
Jan 18 Javascript
js使用generator函数同步执行ajax任务
Sep 05 Javascript
javascript数组去重方法总结(推荐)
Mar 20 Javascript
vue实现固定位置显示功能
May 30 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扎实个人基本功
2008/03/27 PHP
Php获取金书网的书名的实现代码
2010/06/11 PHP
基于jquery的商品展示放大镜
2010/08/07 Javascript
jQuery 阴影插件代码分享
2012/01/09 Javascript
js indexOf()定义和用法
2012/10/21 Javascript
jquery滚动组件(vticker.js)实现页面动态数据的滚动效果
2013/07/03 Javascript
Javascript动态创建表格及删除行列的方法
2015/05/15 Javascript
微信浏览器内置JavaScript对象WeixinJSBridge使用实例
2015/05/25 Javascript
javascript中字体浮动效果的简单实例演示
2015/11/18 Javascript
客户端验证用户名和密码的方法详解
2016/06/16 Javascript
jQuery获取table行数并输出单元格内容的实现方法
2016/06/30 Javascript
javascript操作cookie
2017/01/17 Javascript
vue Render中slots的使用的实例代码
2017/07/19 Javascript
使用Node.js实现RESTful API的示例
2017/08/01 Javascript
php结合js实现多条件组合查询
2019/05/28 Javascript
一文了解vue-router之hash模式和history模式
2019/05/31 Javascript
详解Vue-cli3.X使用px2rem遇到的问题
2019/08/09 Javascript
Antd的Table组件嵌套Table以及选择框联动操作
2020/10/24 Javascript
深入理解Python 代码优化详解
2014/10/27 Python
Python中的面向对象编程详解(下)
2015/04/13 Python
实例探究Python以并发方式编写高性能端口扫描器的方法
2016/06/14 Python
python读取Excel实例详解
2018/08/17 Python
Python pymongo模块常用操作分析
2018/09/01 Python
Python使用sqlalchemy模块连接数据库操作示例
2019/03/13 Python
python ChainMap 合并字典的实现步骤
2019/06/11 Python
python数据类型之间怎么转换技巧分享
2019/08/20 Python
python 默认参数相关知识详解
2019/09/18 Python
python RSA加密的示例
2020/12/09 Python
中职应届生会计求职信
2013/10/23 职场文书
高二政治教学反思
2014/02/01 职场文书
陈欧的广告词
2014/03/18 职场文书
综合管理员岗位职责
2015/02/11 职场文书
2016学习全国教书育人楷模先进事迹心得体会
2016/01/21 职场文书
2016年国庆节假期旅游工作总结
2016/04/01 职场文书
golang通过递归遍历生成树状结构的操作
2021/04/28 Golang
利用python做数据拟合详情
2021/11/17 Python