首页 » 网站建设 » phphtmltabpage技巧_Web前端Tab切换缓存页面处理的几种办法

phphtmltabpage技巧_Web前端Tab切换缓存页面处理的几种办法

访客 2024-12-05 0

扫一扫用手机浏览

文章目录 [+]

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

1.如何切换

phphtmltabpage技巧_Web前端Tab切换缓存页面处理的几种办法

利用动态组件,相信大家都能看懂(部分代码省略)//通过点击就可以实现两个组件来回切换 <button @click=\"大众changeView\"大众>切换view</button> <component :is=\公众currentView\"大众></component> 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.动态天生tab

phphtmltabpage技巧_Web前端Tab切换缓存页面处理的几种办法
(图片来自网络侵删)

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

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

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

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

3.缓存组件

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

3.1 keep-alive

<keep-alive>是Vue的内置组件,能在组件切换过程中将状态保留在内存中,防止重复渲染DOM。
<keep-alive> 包裹动态组件时,会缓存不活动的组件实例,而不是销毁它们。
<keep-alive> 与 <transition>相似,只是一个抽象组件,它不会在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】可以得到我整理的这些前端资料了(私信方法:点击我头像进我主页有个上面有个私信按钮)

标签:

相关文章