vue 手机端tab切换页面不刷新(vue Tab切换以及缓存页面处理的几种方式)
vue 手机端tab切换页面不刷新
vue Tab切换以及缓存页面处理的几种方式目录
- 1.如何切换
- 2.动态生成tab
- 3.缓存组件
- 3.1 keep-alive
- 3.2 使用
- 3.3 缓存组件的生命周期函数
使用动态组件,相信大家都能看懂(部分代码省略)
//通过点击就可以实现两个组件来回切换 <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一般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代码部分如上 <li 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> </li> </template>
以上代码并非实际代码,只提供一个大概的思路。至于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来缓存固定组件,会无效
//无效 <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来处理需要缓存的组件/路由
include有几种用法,可以是数组,字符串用标点隔开,也可以是正则,使用正则的时候需要使用v-bind来绑定。
<keep-alive include="['a','b']">//缓存name为a,b的组件 <keep-alive include ="a,b">//缓存name为a,b的组件 <keep-alive :include="/^store/">//缓存name以store开头的组件 <router-view/>//可以为router-view <component :is="view"></component>//也可以是动态组件 </keep-alive>
使用exclude来排除不需要缓存的路由
跟include正好相反,在exclude里的组件不会被缓存。用法类似,不作赘述
3.2.3 一种比较奇怪的情况
当页面跳转方式有A->C和B->C两种,但是我们从A到C的时候,不需要缓存,从B到C的时候需要缓存。这时候就要用到路由的钩子结合老版本用法来实现了。
export default { data() { return {}; }, methods: {}, beforeRouteLeave(to, from, next) { to.meta.keepAlive = false; // 让下一页不缓存 next(); } };
export default { data() { return {}; }, methods: {}, beforeRouteLeave(to, from, next) { // 设置下一个路由的 meta to.meta.keepAlive = true; //下一页缓存 next(); } };
3.3 缓存组件的生命周期函数
缓存组件第一次打开的时候,和普通组件一样,也需要执行created, mounted等函数。
但是在被再次激活和被停用时,这几个普通组件的生命周期函数都不会执行,会执行两个比较独特的生命周期函数。
- activated
这个会在缓存的组件重新激活时调用
- deactivated
这个会在缓存的组件停用时调用
以上就是vue Tab切换以及缓存页面处理的几种方式的详细内容,更多关于vue Tab切换以及缓存页面处理的资料请关注开心学习网其它相关文章!
- vuephp后台开发框架(Vue+thinkphp5.1+axios实现文件上传)
- vue文件上传进度处理(Vue 大文件上传和断点续传的实现)
- vue中router的具体用法(vue-router中hash模式与history模式的区别)
- vue加element ui开发项目(Vue+ElementUI之Tree的使用方法)
- vue监控对象变化(Vue之监听方法案例详解)
- vueelementui组件生成页面(Vue Element前端应用开发之树列表组件)
- vue 手机端tab切换页面不刷新(vue Tab切换以及缓存页面处理的几种方式)
- vue3 动态生成组件(如何在vue3.0+中使用tinymce及实现多图上传文件上传公式编辑功能)
- vue组件之间的通信(超详细的vue组件间通信总结)
- vue 怎么设置滚动条的长度(vue使用better-scroll实现横向滚动的方法实例)
- vue定时器中间变颜色(Vue如何优雅的清除定时器)
- vue 组件布局(Vue实现固定底部组件的示例)
- vue中什么时候需要set属性(Vue.set和this.$set使用和区别)
- vue设置属性没响应(Vue.$set 失效的坑 问题发现及解决方案)
- vue 组件如何转换虚拟dom(Vue源码分析之虚拟DOM详解)
- vuejs图片缩放裁切(vue+js点击箭头实现图片切换)
- 哪里可以看熊猫(成都哪里可以看熊猫)
- oppo手机的三种录屏方法,你知道有哪些吗(oppo手机的三种录屏方法)
- 吉林神秘传染链跨省 传染源尚未找到,舒兰 封城(吉林神秘传染链跨省)
- 吉林舒兰 封城 聚集性疫情传播链已延至沈阳,有一个细节让人忧心(吉林舒兰封城)
- 1天密接者猛增77人,患者轨迹透露危险信号 吉林市全面封闭管理(1天密接者猛增77人)
- 吉林舒兰 封城 15人确诊 276人隔离,出现跨省传播(吉林舒兰封城)
热门推荐
- springboot内置tomcat启动过程(Tomcat启动springboot项目war包报错:启动子级时出错的问题)
- 国外云主机可以备案吗(云主机免备案是什么?)
- php上传图片视频代码(详解PHP素材图片上传、下载功能)
- 织梦安装图文教程(织梦网站安装教程 织梦模板通用安装图文教程)
- css鼠标点击效果怎么样(CSS实现鼠标滑过鼠标点击代码写法)
- mysql 操作日志(MySQL中的undo日志)
- dedecms内容页代码(DEDECMS生成HTML时提示 DedeTag Engine Create File False的解决方法)
- docker容器的标准使用过程(Docker容器的使用方法简单示例)
- mvc中@helper的用法
- laravel8 前后端分离方案(laravel 根据不同组织加载不同视图的实现)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9