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

前言

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

1.如何切换

ee6fa118bf93c545fbed306b3864b640.png
  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页并且可以随时关闭呢(如下图)?

0f87358ff17ec0c547efa30f8badb8ac.png

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

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

e42c9b54cf4af5c5173db6811b0d6129.png

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

3.缓存组件

7757e09b6639aecc0880f0851eb273c9.png

仅仅是做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】可以得到我整理的这些前端资料了(私信方法:点击我头像进我主页有个上面有个私信按钮)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/428062.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

20165203 2017-2018-2 《Java程序设计》第一周学习总结

20165203 2017-2018-2《Java程序设计》第一周学习总结 教材学习内容总结 (一)Java的地位 Java是面向对象编程,并涉及网络、多线程等重要的基础知识,是一门很好的面向对象的语言。 (二)Java的特点 简单 面向…

C语言中printf输出特殊字符(“%d“或者“\n“)

在C语言中,相信很多人尝试过进行“%”的输出,常规的 printf("%d\n"); 肯定是行不通的,这里需要注意的是在c语言中对“%”和“\”的输出是可以的,但是输出格式不能直接进行输出,编译器在编译的时候会把"…

此处不允许使用分组函数_Excel中使用Vlookup函数实现数据分组

Vlookup匹配函数:在表格的首列查找指定的数据,并返回指定的数据所在行中的指定列处的单元格内容。该函数的语法规则如下:VLOOKUP(lookup_value,table_array,col_index_num,range_lookup)draft-node"block" data-draft-type"ta…

C#细说多线程(下)

本文主要从线程的基础用法,CLR线程池当中工作者线程与I/O线程的开发,并行操作PLINQ等多个方面介绍多线程的开发。 其中委托的BeginInvoke方法以及回调函数最为常用。而 I/O线程可能容易遭到大家的忽略,其实在开发多线程系统,更应该…

cpp [Error] reference to ‘count‘ is ambiguous(全局变量的使用模糊不清)

在编写汉诺塔实验的时候,自己设计了一个全局的计数变量count用来计数移动次数,结果运行的时候报了这样的错误,错误也锁定在全局变量的定义那里。 没想通为什么会有语法错误,去查了一下发下是c的库函数有关键字count,所…

InfluxDB学习之InfluxDB数据保留策略(Retention Policies)

InfluxDB每秒可以处理成千上万条数据,要将这些数据全部保存下来会占用大量的存储空间,有时我们可能并不需要将所有历史数据进行存储,因此,InfluxDB推出了数据保留策略(Retention Policies),用来…

车牌识别数据集_行人再识别数据集

目前行人再识别的数据集比较常用的有:Market-1501、 DukeMTMC-reID、CUHK03,后面有时间会上传如何处理数据集的代码。目前常使用的方式:数据集下有以下几个文件夹:train:包含n个子文件夹,每个文件夹是对应标…

浅谈web前端理解一(前端学习路线)

提到学习web前端,在外行人或者初学者的眼里,应该是绚丽的画面,精彩的布局,或者各种UI以及依据前端开发出来的小游戏。但经过一段时间的学习,你会发现其实本质上是一种搬砖经验的积累,以及布局框架的积累。 …

最长非降子序列(动态规划dp dynamic programming)

首先要理解一下什么叫做非降子序列 非降子序列,简单来说就是指给出一个数字序列,在不改变整体顺序的情况下摘出几个来组成一个子序列,这个序列满足从小到大的排序顺序。 所以,最长非降子序列,不难理解就是从这些子序列…

textarea回车不换行 小程序_微信小程序商城到底值得不值得开通?

微信小程序商城到底值得不值得开通?小程序不用下载,而且具有自带流量功能,成为线下店铺和移动互联网的营销利器。众多企业为了提高知名度,开发了小程序商城,在此,建议,不管有没有微信商城&#…

递归——阶乘加斐波那契数列(简单掌握递归思想的敲门砖)

话不多说&#xff0c;先上源码: 阶乘: #include<iostream> #include<bits/stdc.h> using namespace std;int JieCheng(int n);int main() {int n;cin>>n;cout<<n<<"的阶乘是:"<<JieCheng(n)<<endl; }int JieCheng(int n…

思维导图下载 注册安全_【思维导图】初中各科思维导图,涵盖3年各科所有知识点,可下载打印!...

点击☝上方蓝字&#xff0c;关注“初中资料”再点击右上角“...”菜单&#xff0c;选择“设为星标”深圳资深教师&#xff0c;解读升学政策&#xff0c;分享独家资料初中数学思维导图&#xff0c;涵盖初中所有知识点初中语文思维导图&#xff0c;涵盖初中所有知识点初中英语思维…

爬楼梯(递归——奇数步,偶数步扩展)

题目: 假设你正在爬楼梯。需要 n 阶你才能到达楼顶。 每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢&#xff1f; 思路: 采用递归的思想&#xff0c;最后一步可以爬1个或者两个台阶&#xff0c;所以可以得出递归关系:爬n阶台阶的爬法等于爬&#xff08;n-1&…

空间留言软件_电脑硬盘空间提示不足,原来还可以这么做,真是学到老活到老...

Hello大家好&#xff0c;我是兼容机之家的咖啡咖啡最近收到好多留言&#xff0c;有的就说到自己电脑c盘空间莫名减少&#xff0c;电脑磁盘储存空间不足&#xff0c;无论怎么删减东西都是感觉空间不够用。今天就这个问题&#xff0c;咖啡跟大家总结一下。总的来说&#xff0c;空…

Linux vim编写编译运行一个.c文件(centeos 8 HelloWorld.c)

1.先在一个编译器里&#xff0c;编辑HelloWorld.c的代码&#xff0c;这里以dev为例。 #include<stdio.h> int main() {pintf("Hello World!\n");return 0; }2.打开VMware&#xff0c;开启虚拟机&#xff0c;打开终端。 进行如下操作: 1.vim HelloWorld.c 2.点…

回溯求解排列组合(求源码评论区留言)

回溯求解排列组合的关键在于两点: 一是要明白回溯的思想到底是什么 二是要考虑清楚什么时候进行向下探索&#xff0c;什么时候碰壁回头&#xff0c;什么时候到达回溯的重点&#xff0c;退出循环。也就是回溯过程中的约束条件 回溯思想:向前走&#xff0c;碰壁回头 回溯的一般形…

微星刀锋 无法进入bios_夏天来了 微星主板风扇转速调节攻略

差不多还有1个多月夏天就要来临&#xff0c;现在的新电脑大多6核与8核&#xff0c;甚至12核都有&#xff0c;散热问题是电脑每年夏季的必备功课。为此今天咱们就来教大家如何使用BIOS和软件Dragon Center来调节CPU及系统风扇。BIOS调节以CLICK BIOS 5界面为例&#xff0c;进入B…

回溯——伯努利装错信封问题

这一道题与回溯法写的排列组合是很类似的&#xff0c;只是多了第一个的约束条件的限制&#xff0c;就是除了选出来的数都能相同&#xff0c;而且第i个数也不能等于它本身的自然位。 对于回溯思想的解读&#xff0c;可见回溯法求解排列组合 运行结果: 源码这里暂时不予给出&…

wifi 信道_说了这么久的信道和频宽,这回总算能弄明白啦

转自头条号ZBT科研站为了让家里各处信号都满格&#xff0c;太多的人进行了思考和折腾。通过多方实验证明&#xff0c;改变信道是改善家庭中wifi信号差问题的办法之一。因此下面我们来了解一下&#xff0c;拥挤的信道路由器怎么设置才能够得到更好的wifi信号。时常有人问到&…

手工机器人的做法大全用易拉罐_纯手工自制黄油,做法简单详细易操作,蛋糕、饼干、面包都能用...

哈喽大家好我是老左&#xff0c;我想会有很多人和我一样会有很多的疑问&#xff0c;黄油到底是怎么来的&#xff1f;为什么黄油吃起来会那么的香&#xff0c;而且蛋糕、饼干、面包都能用得到&#xff0c;带着这些个疑问老左查询了一番&#xff0c;原来黄油是这样做的。今天老左…