前言

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

1.如何切换

  1. 使用动态组件,相信大家都能看懂(部分代码省略)//通过点击就可以实现两个组件来回切换 切换view 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. 使用路由(这个就是配置路由的问题了,不作赘述)

2.动态生成tab

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

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

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

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

3.缓存组件

仅仅是做tab切换,远远是不够的,毕竟大家想要tab页就是要来回切换操作,我们需要保存他在不同tab里操作的进度,比如说填写的表单信息,或者已经查询好的数据列表等。那么我们要怎么缓存组件呢?
只需要用到vue中的keep-alive组件

3.1 keep-alive

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

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

3.2 使用

3.2.1 老版本vue 2.1之前的使用

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

3.2.2 比较新而且简单的用法

  • 直接缓存所有组件/路由
  • 使用include来处理需要缓存的组件/路由

include有几种用法,可以是数组,字符串用标点隔开,也可以是正则,使用正则的时候需要使用v-bind来绑定。

  • 使用exclude来排除不需要缓存的路由

跟include正好相反,在exclude里的组件不会被缓存。用法类似,不作赘述

3.2.3 一种比较奇怪的情况

当页面跳转方式有A->C和B->C两种,但是我们从A到C的时候,不需要缓存,从B到C的时候需要缓存。这时候就要用到路由的钩子结合老版本用法来实现了。

3.3 缓存组件的生命周期函数

缓存组件第一次打开的时候,和普通组件一样,也需要执行created, mounted等函数。
但是在被再次激活和被停用时,这几个普通组件的生命周期函数都不会执行,会执行两个比较独特的生命周期函数。

  • activated
    这个会在缓存的组件重新激活时调用
  • deactivated
    这个会在缓存的组件停用时调用

结语

这个是很基础的知识,放在笔记里很久了,不过之前记得有点乱,今天拿出来抖一下尘~
如果有建议或者有不对的地方,请在评论区指出,谢谢大家。

喜欢小编文章的可以点个赞关注小编哦,小编每天都会给大家更新文章。

我自己是一名从事了多年的前端老程序员,小编为大家准备了新出的前端编程学习资料,免费分享给大家!

如果你也想学习前端,那么帮忙转发一下然后再关注小编后私信【1】可以得到我整理的这些前端资料了(私信方法:点击我头像进我主页有个上面有个私信按钮)

uniapp滑动切换tab标签_Web前端,Tab切换,缓存,页面处理的几种方式相关推荐

  1. vue中怎么清空tab选项卡的缓存_vue Tab切换以及缓存页面处理的几种方式

    前言 相信tab切换对于大家来说都不算陌生,后台管理系统中多会用到.如果不知道的话,可以看一下浏览器上方的标签页切换,大概效果就是这样. 1.如何切换 使用动态组件,相信大家都能看懂(部分代码省略) ...

  2. python 后端接受前端传到后端的数据的四种方式

    python 后端接收前端传到后端的数据的4种方式 1,以查询字符串的方式传入 def test(request): #查询字符串方式传参的获取a = request.GET.get('a') #a为 ...

  3. 线上前端静态资源代理到本地的几种方式

    前言 我是一个小前端,前段时间开始支持集团监控平台业务. 当我拉下代码,开启本地服务,出现了一大堆请求错误. 原因是:本地的host是127.0.0.1,而接口调用的是线上数据. 接口的host和平台 ...

  4. 前端获取div里面的标签_web前端教程JavaScript学习笔记DOM

    web前端教程JavaScript学习笔记 DOM一DOM(Document Object Model): 文档对象模型 其实就是操作 html 中的标签的一些能力 我们可以操作哪些内容 获取一个元素 ...

  5. css 大于号 标签_web前端教程之怎样学好css?

    web前端教程之怎样学好css?我推荐题主的学习方法就是:善用调试工具. 使用谷歌浏览器进行调试,在属性不理解时可以直接在浏览器里进行数值调节 css在书写时由于选择器权重问题经常出现样式覆盖的问题 ...

  6. button按钮的属性设置_web前端入门到实战:CSS实现8种炫酷按钮

    今天给大家分享8种炫酷按钮的CSS实现. 1. 3D按钮1 现在的主流是扁平化的设计,拟物化的设计比较少见了,所以我们仅从技术角度去分析如何实现这个3D按钮 该按钮的立体效果主要由按钮多出的左.下两个 ...

  7. 前端实现HTML转PDF下载的两种方式

    方式一:使用html2canvas和jspdf插件实现 该方式是通过html2canvas将HTML页面转换成图片,然后再通过jspdf将图片的base64生成为pdf文件.实现步骤如下: 1,下载插 ...

  8. input禁止光标_表单中readonly的input等标签,禁止光标进入(focus)的几种方式

    需求及问题描遇新是直朋能到述 在做移动端页面,需要在订单页面中显示表单数据,由于UI统一,所以就依旧采用form的结构来写结构,只读数据的标签自然要加readonly="readonly&q ...

  9. html另存为对话框,前端实现弹出“另存为”对话框的三种方式

    今天开发一个需求,需要将一段字符串保存到文件中,并且保存之后在页面上弹出"另存为"对话框来实现将文件保存到指定位置.那么应该如何来实现在前端弹出"另存为"对话框 ...

最新文章

  1. 互联网引发全面深刻产业变革
  2. exchange之2003迁移至2007
  3. mysql数据库字符集设置
  4. cgo引用定义不一致_应急照明、消防应急照明和疏散指示系统的定义与分类
  5. java如何读取word的占位符_java利用xml导出word(占位符替换)
  6. Express2.X迁移至3.X注意事项
  7. [JZOJ5426]摘Galo
  8. Linux:9个实用shell运维脚本,值得收藏!
  9. 企业信息化建设过程中,交通物流行业如何凭借数据成功转型?
  10. 专门跑顺风车真的挣钱吗?
  11. .NET文档生成工具ADB[更新至2.3]
  12. excel html id,excel.html
  13. Hdfview安装教程ubuntu
  14. NSIS 封装软件工具封装的软件,安装后快捷方式没有图标显示问题
  15. uni-app小程序与app端的兼容问题
  16. 【历史上的今天】6 月 6 日:世界 IPv6 启动纪念日;《俄罗斯方块》发布;小红书成立
  17. scala case 常用简写
  18. python3遍历目录查找文件
  19. 情景软工编程题(待更新)
  20. 【论问阅读】VERY DEEP CONVOLUTIONAL NETWORKS FOR LARGE-SCALE IMAGE RECOGNITION

热门文章

  1. ASP.NET小技巧——回传后保持页面的滚动位置
  2. tomcat9-jenkins:insufficient free space available after evicting expired cache entries-consider
  3. 【bug】HbuilderX运行到微信小程序 报错
  4. 2019年终总结-2020展望「持续更新至31号」
  5. 自定义EditText输入框
  6. Android 带阴影背景图片
  7. 跳出内层循环 使用 for of 代替 map
  8. 系统垃圾清理.cmd
  9. ie 调用java的时候报错,调用javabean的非常郁闷的异常。
  10. Spring Boot缓存注解@Cacheable、@CacheEvict、@CachePut使用