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 "htmlcode">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() })以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
vue单页缓存
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]