前端如何给特定的组件设置缓存并处理定位问题?

前端如何给某些组件设置缓存并处理定位?

最近有个需求就是a=>b,b页面处理了些操作,返回a页面时,

b页面若有操作则a页面需要刷新并定位到上次点击的位置,b若没有操作则无需刷新直接定位上次点击的位置

1.首先在store中存储缓存的组件

javascript 复制代码
vuex代码:
const cached = {
  state: {
    cachedPage: []
  },
  getters: {
    getCachedPage (state) {
      return state.cachedPage;
    }
  },
  actions: {
    addCached ({ commit }, view) {
      console.log('view', view)
      commit('ADD_CACHED', view)
    },
    delCached ({ commit }, view) {
      commit('DEL_CACHED', view)
    }
  },
  mutations: {
    ADD_CACHED: (state, view) => {
      if (state.cachedPage.includes(view.name)) return;
      state.cachedPage.push(view.name);
    },
    DEL_CACHED: (state, view) => {
      const index = state.cachedPage.indexOf(view.name);
      index > -1 && state.cachedPage.splice(index, 1);
    },
  },
}
export default cached

2.在app.vue组件中使用keep-alive缓存组件
加粗样式

javascript 复制代码
<keep-alive :include="getCachedPage">
    <router-view></router-view>
 </keep-alive>
<script >
import { mapGetters } from 'vuex'; 
export default {
  name: 'App',
  computed: {
    ...mapGetters(['getCachedPage']),
  }, 
</script>

3.在需要缓存的组件中,使用组件内的守卫方法,代码如下:
注意:name不要写错了

javascript 复制代码
export default {
  name: 'home',
  beforeRouteEnter(to, from, next) {
    console.log(from);
    store.dispatch('addCached', to);
    next((vm) => {
      vm.routeName = to.name;
    });
  },
  beforeRouteLeave(to, from, next) {
    console.log(to, from);
    //记录上次点击的位置
    this.scrollTop = document.documentElement.scrollTop;
    next();
  },
  activated() {
    //刷新列表
    if (this.routeName === 'details') {
      //调用刷新列表的接口
    } else {
      //无需刷新缓存
      document.documentElement.scrollTop = this.scrollTop;
    }
  },
}
相关推荐
kyriewen23 分钟前
你写的代码没有测试,就像出门不锁门——Jest + Testing Library 从入门到不慌
前端·单元测试·jest
yuzhiboyouye1 小时前
web前端英语面试
前端·面试·状态模式
我是唐青枫2 小时前
终于不用手搓两级缓存了!C#.NET HybridCache 详解:L1 L2、标签失效与防击穿实战
redis·缓存·c#·.net
:mnong2 小时前
附图报价系统设计分析5
electron·pdf·vue·cad·dwg·定额
canonical_entropy2 小时前
下一代低代码渲染框架 nop-chaos-flux 的设计原则
前端·低代码·前端框架
东方小月2 小时前
5分钟搞懂Harness Engineering(驾驭工程):从提示词到AI Agent的进化之路
前端·后端·架构
我叫黑大帅2 小时前
为什么需要 @types/react?解决“无法找到模块 react 的声明文件”报错
前端·javascript·面试
之歆3 小时前
DAY_21JavaScript 深度解析:数组(Array)与函数(Function)(一)
前端·javascript
XinZong3 小时前
【AI社交】基于OpenClaw自研轻量化AI社交平台实战
前端
Le_ee4 小时前
ctfweb:php/php短标签/.haccess+图片马/XXE
开发语言·前端·php