npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

blue-retreat

v1.0.6

Published

vue keep-alive popstate manage

Downloads

3

Readme

blue-retreat

Vue KeepAlive 后退处理

简介

Vue 提供的 KeepAlive 组件存在一些使用场景上的问题,例如:A 访问 B 页面,从 B 页面后退回到 A 也页面,再重新通过 A 页面访问 B 时,Vue 的策略会直接使用之前的 B 缓存

由此衍生出我们需要做对应的处理来达到后退时清楚对应历史页面的缓存处理。

PS:现阶段考虑到实际的场景中极少数存在多个app实例多个router实例个多个store实例, 对于多个的解决方案多数都为多iframe进行处理多个frame间的router都是独立的,暂时不考虑多实例匹配,当前为单例模式;

额外说明一下: Vue的KeepAlive存在无法越级缓存的问题,如果是越级路由跳转,会把差级内的缓存重置:

  • A->BB->A 实际BX中的X会被重置
  • A->BBB->CC 实际BBX中的X会被重置
  • A->BBB->C 实际BXX中的XX会被重置

依赖:

npm i blue-retreat -S

使用说明

defineBlueRetreat 方法:原initBlueRetreat更名为defineBlueRetreat,请悉知.

Options


router: VueRouter

VueRouter 实例


store: Vuex | Pinia.defineStore

Vuex 实例 或者 Pinia的store


类只存在两个配置,使用起来非常方便。在使用中,页面的name需要和路由中的name匹配,实际所有的name是不一致的

// 在注册路由前使用模块
import {defineBlueRetreat} from 'blue-retreat';
import Router from 'vue-router';
import Vuex from 'vuex';

const router = new Router({
  routes:[{
    path:`page`,
    //必须填上name,而页面中name也是需要和当前的name一致
    name:`page-name`,
  }]
});

const store = new Vuex();

//定义retreat
defineBlueRetreat({
  router,
  store
});

对于使用Pinia

import {defineBlueRetreat} from 'blue-retreat';
import {createApp} from 'vue';
import Router from 'vue-router';
import {createPinia,defineStore} from 'pinia';

//创建vue应用
const app = createApp();

//初始化pinia
app.use(createPinia());

const router = new Router({
  routes:[{
    path:`page`,
    //必须填上name,而页面中name也是需要和当前的name一致
    name:`page-name`,
  }]
});

//初始化retreat defineBlueRetreat
defineBlueRetreat({
  router,
  //如果使用的为pinia,这里只需传入defineStore即可,内部会进行相关的store创建
  store: defineStore
});

app.$mount(`#app`);

通过 getExcludeState 方法获取 exclude 状态

由于 KeepAlive 组件在做缓存时,会使用到页面.vue 文件中的 name 作为唯一表示,我们需要在.vue 文件中定义好 name 值,由于在 router 中获取不到页面的 name,需要定义.vue 文件的 name 同时也要定义路由中的 name || meta.name,如上面例子所示

<KeepAlive :exclude="exclude">
  <RouterView />
</KeepAlive>

<script>
  import { getExcludeState } from "blue-retreat";
  export default {
    //这里的name是唯一的,和router中的meta.name作为匹配使用
    name: `page-name`,
    computed: {
      exclude() {
        //如果有自身需要排除的,可以通过这个方式concat getExcludeState
        return [
          /* 你自己的exclude */
        ].concat(getExcludeState());
      },
    },
  };
</script>

一些特殊场景的处理

场景 1:A->B->C->A->C->B 存在回环处理的,第一个 A 缓存会被删除,后退回到第一个 A 后,A 将会重新初始化 render

场景 2:A->A 的这种情况不做任何处理,需要自身处理$route 的变化,以及的对应业务处理


后退传值

page2

  //page2
  import {setRetreatData} from 'blue-retreat';
  setRetreatData({
    someData:`data`
  });

通过后退到 page1

  //page1
  import {getRetreatData} from 'blue-retreat';
  const retreatData = getRetreatData();
  //retreatData === {someData:`data`}

关于getRetreatData方法

getRetreatData({ once?: boolean = true });

如果被使用一次就会被销毁回默认值{};当然也可以跨页面获取值,可以给到具体需要使用到的页面来使用到值。