vue单页缓存存在的问题及解决方案

news/2024/7/10 1:17:27 标签: vue

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)
},
//前端全栈学习交流圈:866109386
//面向1-3经验年前端开发人员
//帮助突破技术瓶颈,提升思维能力

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 
  },
}
//前端全栈学习交流圈:866109386
//面向1-3经验年前端开发人员
//帮助突破技术瓶颈,提升思维能力

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
  }
}
//前端全栈学习交流圈:866109386
//面向1-3经验年前端开发人员
//帮助突破技术瓶颈,提升思维能力

针对普通分享页面,在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()
})

http://www.niftyadmin.cn/n/1300983.html

相关文章

CocosCreator Java传参数到JS

最近正在接GooglePlay内购&#xff0c;在传参数回CocosCreator的环境的时候&#xff0c;没有调用到JS的方法。 其中错误的写法是: app.runOnGLThread(new Runnable() {Overridepublic void run() {Cocos2dxJavascriptJavaBridge.evalString("buyDiamond("purchase.…

COM与DLL的区别

这阵子在想一个需要利用com组件的小程序怎么做&#xff0c;突然想起上次去面试的时候考官问过autocad开发时为什么要利用com&#xff0c;而不采用一般的dll呢&#xff1f; 到google上查了一下&#xff0c;许多人也问了一样的问题&#xff1a;&#xff09; 用com来写程序…

CocosCreator JS追踪堆栈信息

在开发过程中&#xff0c;可能有这样的需求&#xff1a;即使在没有报错的情况&#xff0c;也需要查看该函数的堆栈调用信息。 对于这样的需求&#xff0c;我们可以使用JS原生的console.trace来实现。 具体代码&#xff1a; export let TraceArr [];console.trace function…

深入解析ES6中的迭代器(Iterator)和生成器(Generator)

用循环语句迭代数据时&#xff0c;必须要初始化一个变量来记录每一次迭代在数据集合中的位置&#xff0c;而在许多编程语言中&#xff0c;已经开始通过程序化的方式用迭代器对象返回迭代过程中集合的每一个元素 迭代器的使用可以极大地简化数据操作&#xff0c;于是ES6也向JS中…

OSI七层网络模型 TCP/IP 三次握手 四次挥手

1、概念 OSI 七层模型 (开放系统互联 Open System Interconnection )

CocosCreator多语言包的处理

如果项目需要国际化的处理&#xff0c;也就是需要切换语言的功能时&#xff0c;一般有两种方案&#xff1a; 单个包 优点&#xff1a; 1.可以动态切换语言&#xff08;当然要代码上实现&#xff09; 2.只有一个版本&#xff0c;容易维护 缺点&#xff1a; 1.安装包大 多…

React 的几种条件渲染以及选择详解

对于一个展示页面来讲, 通常有好几种展示状态(以列表页为例): 数据为空, 空页面取数据时发生错误, 错误页面数据正常加载状态 针对以上三种情况, react渲染列表的时候要正确判断并渲染出相应的视图, 也就是条件渲染. 不同于vue的v-if, v-show等框架提供的api, react的条件渲染…

Android判断系统语言是简体还是繁体

在SDK的版本为24之前&#xff0c;我们获取语言的配置是通过 getResources().getConfiguration().locale; 来获取的&#xff0c;但是24之后&#xff08;包括24&#xff09;“.locale”就弃用了&#xff0c;需要 getResources().getConfiguration().getLocales().get(0); 来获…