Vue —— keepAlive使用(指定页面跳转缓存)

功能逻辑

HomePage ——> OrderList ——> OrderDetail
1、首页跳转的订单列表页,列表页刷新并请求数据;
2、列表页跳转到详情页,再返回列表页不刷新页面。

一、设置页面缓存

如果想要保住页面不刷新,首先需要设置路由管理。这里需求是OrderList页面不刷新,那么在 router.js 设置如下:

{
    name: 'HomePage',
    path: '/HomePage',
    component: () => import('./page/HomePage.vue')
  },
  {
    name: 'OrderList',
    path: '/OrderList',
    component: () => import('./page/OrderList.vue'),
    meta: {
      keepAlive: true
    }
  },
  {
    name: 'OrderDetail',
    path: '/OrderDetail',
    component: () => import('./page/OrderDetail.vue')
  }

meta: { keepAlive: true} 设置后页面保持缓存,无论怎么访问均显示第一次缓存的内容。

二、设置页面跳转回调方法

这里回调主要是控制页面刷新的行为,所以只要在OrderList页面里处理这方面的逻辑。介绍两个方法:
1、beforeRouteLeave:页面跳转/返回前的回调方法,可以在离开当前页面之前做自定义的处理;
2、activated:页面激活时的回调方法,无论是返回还是跳转到此页面都会触发。

坑在这里

一开始在OrderList设置了跳转回调,如下:

beforeRouteLeave(to, from, next) {
    if (to.name == "OrderDetail") {
      from.meta.keepAlive = true;
    } else {
      from.meta.keepAlive = false;
    }
    next();
  }

逻辑上在跳转到OrderDetail前设置OrderList保持缓存为true,返回到HomePage前设置OrderList保持缓存为false。理论上没有问题,但是实际测试时缓存并没有保存,从OrderDetail返回以后数据一片空白。可以知道这样缓存机制在目前的VUE版本是实现不了的。

解决方案

在上面动态设置缓存状态行不通的情况下,只能自定义字段来判断一下OrderList页面是否需要刷新数据。前提就是默认OrderList页面是有缓存的,就是上面在 router.js 中的设置。
自定义后的OrderList代码如下:

data() {
    return {
      needRefresh: true //判断页面是否需要刷新
    };
  },
beforeRouteLeave(to, from, next) {
    if (to.name == "OrderDetail") {
      this.needRefresh = false;
    } else {
      this.needRefresh = true;
    }
    next();
  },
 activated() {
   if (this.needRefresh) {
     this.getOrderList();
   }
 },

逻辑很简单,加个needRefresh标识,在进入/回到不同页面时设置变量值,在每次页面唤醒activated回调时判断是否需要刷新,根据需要进行处理即可。

Vue中实现跳转详情页,可以使用Vue Router。下面是一个简单的例子: 1. 首先,在router/index.js文件中定义路由: ```javascript import Vue from 'vue' import Router from 'vue-router' import Detail from '@/components/Detail' import Home from '@/components/Home' Vue.use(Router) export default new Router({ routes: [ { path: '/', name: 'Home', component: Home }, { path: '/detail/:id', name: 'Detail', component: Detail } ] }) ``` 在这里,我们定义了两个路由:Home和Detail。其中Detail路由包含一个参数:id,表示详情页的id。 2. 在Home组件中,我们可以使用router-link标签来实现跳转: ```html <template> <div> <h1>Home Page</h1> <ul> <li v-for="item in list" :key="item.id"> <router-link :to="{ name: 'Detail', params: { id: item.id }}">{{ item.title }}</router-link> </li> </ul> </div> </template> <script> export default { data() { return { list: [ { id: 1, title: 'Article 1' }, { id: 2, title: 'Article 2' }, { id: 3, title: 'Article 3' } ] } } } </script> ``` 在这里,我们使用了v-for指令遍历文章列表,并使用router-link标签来包装每个文章标题。当用户点击标题时,路由会自动跳转到详情页,并将对应的id传递给Detail组件。 3. 在Detail组件中,我们可以通过$route对象来获取id参数: ```html <template> <div> <h1>Detail Page</h1> <p>Article ID: {{ $route.params.id }}</p> </div> </template> <script> export default { mounted() { // 在这里可以根据id加载文章内容 console.log('Article ID:', this.$route.params.id) } } </script> ``` 在这里,我们使用$route.params.id来获取路由参数中的id值,并在mounted钩子函数中打印它。你可以在这里编写相应的业务逻辑,例如根据id加载文章内容。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值