博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
vue单页缓存存在的问题及解决方案(小结)
阅读量:6037 次
发布时间:2019-06-20

本文共 3127 字,大约阅读时间需要 10 分钟。

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

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

子组件同名样式加上deep

前端精品教程:

1
2
3
4
5
6
7
8
/deep/ .tabs-row {
 
.items-wrp{
  
padding-left
: .
34
rem;
 
}
 
.item {
  
margin
:
0
.
12
rem .
16
rem
0
;
 
}
}

2.事件全局绑定

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

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

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

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

前端精品教程:

1
2
3
4
5
6
7
8
9
10
activated () {
 
// 不直接绑定scroll,此处有限制
 
this
.bindEvent()
},
destroyed () {
 
$(window).off(
'scroll'
,
this
.handleScrollFn)
},
deactivated () {
 
$(window).off(
'scroll'
,
this
.handleScrollFn)
},

3.音频续播

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

1
2
3
4
5
6
7
8
9
deactivated () {
  
// 前进时暂停音频播放
  
this
.pauseAudio()
 
},
methods: {
  
pauseAudio () {
   
this
.$refs.audioPlayer &&
this
.$refs.audioPlayer.togglePlay()
  
}
}

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

1
2
3
4
5
6
7
8
9
10
11
12
13
destroyed () {
  
this
.closeMini()
//关闭音频播放器
 
},
methods: {
  
closeMini () {
   
this
.mode = -1
   
this
.play =
false
   
if
(
this
.player) {
    
this
.player.pause()
   
}
   
this
.$emit(
'callback'
,
'close'
)
  
},
}

4.微信分享数据未更新

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

前端精品教程:

1
2
3
4
5
6
7
8
9
10
11
12
13
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得到下一页,上一页的地址

1
2
3
4
var
referrer = !from.name ? document.referrer :  
  
`${location.origin}${from.fullPath}`
// 通过from.name判断刷新
 
 
var
curUrl = `${location.origin}${to.fullPath}` ||
''

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

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

1
window.location.hash =
'#refer'

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

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

7.分享问题修复

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

1
2
3
4
5
6
7
8
9
10
11
12
activated () {
  
this
.setShare(
this
.shareCache)
 
},
 
 
methods: {
  
setShare (opt) {
   
if
(!opt)
return
// xx.setShare封装的分享的底层方法
   
xx.setShare && xx.setShare(opt)
   
this
.shareCache = opt
  
}
}

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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
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提示在返回时未消失,因为延迟时间设置,解决方法:在路由钩子里边强制隐藏

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

转载于:https://www.cnblogs.com/zanguixuan/p/9813167.html

你可能感兴趣的文章
Dubbo OPS工具——dubbo-admin & dubbo-monitor
查看>>
Dungeon Master ZOJ 1940【优先队列+广搜】
查看>>
Delphi 中的 XMLDocument 类详解(5) - 获取元素内容
查看>>
2013年7月12日“修复 Migration 测试发现的 Bug”
查看>>
学习vue中遇到的报错,特此记录下来
查看>>
CentOS7 编译安装 Mariadb
查看>>
jstl格式化时间
查看>>
一则关于运算符的小例
查看>>
centos7 ambari2.6.1.5+hdp2.6.4.0 大数据集群安装部署
查看>>
cronexpression 详解
查看>>
一周小程序学习 第1天
查看>>
小孩的linux
查看>>
SpringMVC、MyBatis声明式事务管理
查看>>
开发者详解:端游及手游服务端的常用架构
查看>>
JavaScript History对象
查看>>
在 Windows 下安装 Oracle 11g XE (Express Edition)
查看>>
ListView优化
查看>>
【原创】 PostgreSQL 实现MySQL 的auto_increment 字段
查看>>
vs2015添加vc助手
查看>>
检测点1.1
查看>>