专栏名称: SegmentFault思否
SegmentFault (www.sf.gg)开发者社区,是中国年轻开发者喜爱的极客社区,我们为开发者提供最纯粹的技术交流和分享平台。
目录
相关文章推荐
程序猿  ·  41岁DeepMind天才科学家去世:长期受 ... ·  14 小时前  
程序员的那些事  ·  清华大学:DeepSeek + ... ·  昨天  
OSC开源社区  ·  宇树王兴兴早年创业分享引围观 ·  2 天前  
OSC开源社区  ·  2024: 大模型背景下知识图谱的理性回归 ·  2 天前  
程序猿  ·  “我真的受够了Ubuntu!” ·  2 天前  
51好读  ›  专栏  ›  SegmentFault思否

Tab 切换以及缓存页面处理的几种方式

SegmentFault思否  · 公众号  · 程序员  · 2019-11-09 10:30

正文

SegmentFault 社区文章
作者:李大雷



No.1

前言



相信 tab 切换对于大家来说都不算陌生,后台管理系统中多会用到。 如果不知道的话,可以看一下浏览器上方的标签页切换,大概效果就是这样。


No.2

如何切换



1、使用动态组件,相信大家都能看懂 (部分代码省略)

//通过点击就可以实现两个组件来回切换

is="currentView">

import pageA from "@/views/pageA";
import pageB from "@/views/pageB";

computed: {
  currentView(){
      return this.viewList[this.index];
  }
},
 methods: {
  changeView() {
    this.index=(++this.index)%2
  }
}


   
注:这个多用于单页下的几个子模块使用,一般切换比较多使用下面的路由

2、使用路由 (这个就是配置路由的问题了,不作赘述)


No.3

动态生成 tab



一般 UI 框架给我们的 tab 切换都像是上面的那种,需要自己写入几个 tab 页之类的配置。但是我们如果想要通过点击左边的目录来生成一个 tab 页并且可以随时关闭呢 (如下图)


只需要给路由一个点击事件,把你的路由地址保存到一个列表,渲染成另一个平铺的 tab 目录即可。

假设你的布局是这样,左边的目录,上边的 tab,有字的是页面。


<menu>
  <menu-item v-for="(item,index) in menuList" :key="index" @click="addToTabList(item.path)">
    <router-link :to="item.path">{{item.name}}router-link>
  <menu-item>
menu>

<template>
  <menu class="left"/>//menu代码部分如上
  <div class="right">
    <tab-list>
      <tab-item v-for="(item,index) in tabList" :key="index">
        <router-link :to="item.path">{{item.name}}router-link>
        <icon class="delete" @click="deleteTab">icon>
      tab-item>
    tab-list>
    <page-view>
      <router-view>router-view>//这里是页面展示
    page-view>
  div>
template>

以上代码并非实际代码,只提供一个大概的思路。 至于 addToTabList 和 deleteTab 怎么做就是数组方法的简单 push 和 splice 操作了。 为了效果好看,我们可能还需要一些 tab 的 active 样式,这里不作演示。


No.4

缓存组件



仅仅是做 tab 切换,远远是不够的,毕竟大家想要 tab 页就是要来回切换操作,我们需要保存他在不同 tab 里操作的进度,比如说填写的表单信息,或者已经查询好的数据列表等。

那么我们要怎么缓存组件呢?

只需要用到 vue 中的 keep-alive 组件

3.1 keep-alive


是 Vue 的内置组件,能在组件切换过程中将状态保留在内存中,防止重复渲染 DOM。
包裹动态组件时,会缓存不活动的组件实例,而不是销毁它们。
相似,只是一个抽象组件,它不会在 DOM 树中渲染 (真实或者虚拟都不会) ,也不在父组件链中存在,比如:你永远在 this.$parent 中找不到 keep-alive 。

注: 不能使用 keep-alive 来缓存固定组件,会无效。

//无效

  <my-component>my-component>
keep-alive>

3.2 使用


3.2.1 老版本 vue 2.1之前的使用


<keep-alive>
    <router-view v-if="$route.meta.keepAlive">router-view>
keep-alive>
<router-view v-if="!$route.meta.keepAlive">router-view>

需要在路由信息里面设置 router 的元信息 meta。

export default new Router({
  routes: [
    {
      path: '/a',
      name: 'A',
      component: A,
      meta: {
        keepAlive: false // 不需要缓存
      }
    },
    {
      path'/b',
      name: 'B',
      component: B,
      meta: {
        keepAlive: true // 需要被缓存
      }
    }
  ]
})

3.2.2 比较新而且简单的用法


直接缓存所有组件/路由

<keep-alive>
    <router-view/>
keep-alive>

<keep-alive>
   <component :is="view">component>
keep-alive>

使用 include 来处理需要缓存的组件/路由






请到「今天看啥」查看全文