解决vant中 tab栏遇到的坑 van-tabs


Posted in Javascript onNovember 04, 2020

话不多说,先看下问题描述:

我的需求:(和头条的tab栏类似 ,单击查看头条tab栏)

点击tab栏,下方展示出来当前tab栏下的内容列表(A页面),点击列表进入详情内容(B页面),但是返回(A页面)的时候,需要显示刚才被点击的tab栏高亮显示。(如果tab栏横向有滚动条,那也得让被选中的高亮显示)。

所以,大部分人的解决办法就是将当前选中的tab的索引缓存起来,等回到该页面的时候,让被缓存的那个高亮显示出来。

坑的问题在于:van-tabs,里面的v-model默认值是0,但是类型却写着 number | string 。

解决vant中 tab栏遇到的坑 van-tabs

但是,在此时用缓存赋值给 v-model = " active " 的时候,active的值需要是number类型,才有效,否则再怎么设置都是无效的。

【代码放入项目可直接执行】

<template>
 <div>
  <van-tabs v-model="active" 
   @click="tabHandler"
   :ellipsis="false"
   :border="false"
   >
   <van-tab v-for="(tabname,idx) in tabList" :key="idx" :title="tabname"></van-tab>
  </van-tabs>
  <van-button @click="toDetailHandler">去详情页</van-button>
 </div>
</template>
<script>
export default{
 data(){
  return{
   active: Number(localStorage.getItem('activeIdx'))?Number(localStorage.getItem('activeIdx')):0,
   tabList:['111111','2222222','3333333','44444444','55555','666666','7777777','88888','999999999'],
  }
 },
 methods:{
  // tab点击事件
  tabHandler(idx){
   this.active = idx;
   localStorage.setItem('activeIdx',idx) // 将选中的tab缓存起来
  },
  // 去详情页
  toDetailHandler(){
   this.$router.push('/tab1')
  }
 }
}
</script>

最终的效果图是这样的,和头条的tab栏的效果是一样的。点击查看 头条tab效果

解决vant中 tab栏遇到的坑 van-tabs

补充知识:vue移动端框架van-sticky粘性布局,实现原理和失效原因及注意点

说到粘性布局,我们最常见的就算在app tab选项卡随页面滚动到顶部后悬停在那,看效果

解决vant中 tab栏遇到的坑 van-tabs

要实现这个效果,最简单的办法就是在css样式里添加position:sticky就可以实现,就这么简单,比用js监听页面滚动,然后达到一定高度样式变为fixed,简单且性能好。

vue 的van-sticky组件实现粘性的原理就是通过添加position:sticky实现的,但是如果你使用了position:sticky后失效,并没有效果的原因有:

1.父元素高度没子元素高,通常为父元素设置height:100%;

2:父元素设置了overflow:hidden,overflow-x:hidden,overflow-y:hidden,或者overflow:auto属性都能影响到

其中父元素是指所有父元素,不单单是上一级父元素,在vue中如果失效了别忘了看app.vue组件里是不是设置了这些。

解决好失效问题后,我们再看van-sticky的其中一个悬停的时候距离顶部的距离offset-top

offset-top单位为px,在pc端没问题,但在移动端就有问题了,比如你设计稿距离顶部的距离为90px,如果你直接offset-top=90,那么在手机上就会距离很远,

用window.devicePixelRatio获取设备的像素,然后再进行换算,说实话不同手机上还是有差别,有的手机达到效果,有的没达到

目前我是用了获取元素offsetHeight在赋值回去,如this.$refs.getheight.offsetHeight,经测试能准确达到固定的位置,

如果各位有其他好办法,请在下面留言,大家一起学习。

以上这篇解决vant中 tab栏遇到的坑 van-tabs就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js之WEB开发调试利器:Firebug 下载
Jan 13 Javascript
Array.prototype 的泛型应用分析
Apr 30 Javascript
前端开发的开始---基于面向对象的Ajax类
Sep 17 Javascript
jQuery EasyUI API 中文文档 - DataGrid数据表格
Nov 17 Javascript
Jquery中的层次选择器与find()的区别示例介绍
Feb 20 Javascript
HTML5+Canvas调用手机拍照功能实现图片上传(上)
Apr 21 Javascript
详解node HTTP请求客户端 - Request
May 05 Javascript
微信小程序的分类页面制作
Jun 27 Javascript
vue中axios防止多次触发终止多次请求的示例代码(防抖)
Feb 16 Javascript
微信小程序图片右边加两行文字的代码
Apr 23 Javascript
JS端基于download.js实现图片、视频时直接下载而不是打开预览
May 09 Javascript
小程序实现密码输入框
Nov 16 Javascript
解决Mint-ui 框架Popup和Datetime Picker组件滚动穿透的问题
Nov 04 #Javascript
基于js实现的图片拖拽排序源码实例
Nov 04 #Javascript
在vant中使用时间选择器和popup弹出层的操作
Nov 04 #Javascript
vue 判断两个时间插件结束时间必选大于开始时间的代码
Nov 04 #Javascript
vant 时间选择器--开始时间和结束时间实例
Nov 04 #Javascript
Vue绑定用户接口实现代码示例
Nov 04 #Javascript
vant picker+popup 自定义三级联动案例
Nov 04 #Javascript
You might like
php中常用编辑器推荐
2007/01/02 PHP
基于PHP选项与信息函数的使用详解
2013/05/10 PHP
PHP定时任务延缓执行的实现
2014/10/08 PHP
php将图片保存入mysql数据库失败的解决方法
2014/12/27 PHP
php实现以只读方式打开文件的方法
2015/03/16 PHP
php获取访问者浏览页面的浏览器类型
2017/01/23 PHP
通过jquery的$.getJSON做一个跨域ajax请求试验
2011/05/03 Javascript
JS刷新框架外页面七种实现代码
2013/02/18 Javascript
jquery 删除字符串最后一个字符的方法解析
2014/02/11 Javascript
jQuery学习笔记之jQuery.fn.init()的参数分析
2014/06/09 Javascript
深入探讨JavaScript、JQuery屏蔽网页鼠标右键菜单及禁止选择复制
2014/06/10 Javascript
js获取元素外链样式的方法
2015/01/27 Javascript
angular2倒计时组件使用详解
2017/01/12 Javascript
vue中实现在外部调用methods的方法(推荐)
2018/02/08 Javascript
Js通过AES加密后PHP用Openssl解密的方法
2019/07/12 Javascript
javascript二维数组和对象的深拷贝与浅拷贝实例分析
2019/10/26 Javascript
实例讲解React 组件
2020/07/07 Javascript
详解Vue中的自定义指令
2020/12/07 Vue.js
[06:44]2014DOTA2国际邀请赛-钥匙体育馆开战 开幕式振奋人心
2014/07/19 DOTA
Python字典数据对象拆分的简单实现方法
2017/12/05 Python
浅谈Python实现贪心算法与活动安排问题
2017/12/19 Python
浅谈Python Opencv中gamma变换的使用详解
2018/04/02 Python
Python双向循环链表实现方法分析
2018/07/30 Python
Python自动化运维之Ansible定义主机与组规则操作详解
2019/06/13 Python
Django跨域资源共享问题(推荐)
2020/03/09 Python
python爬虫爬取某网站视频的示例代码
2021/02/20 Python
OPPO手机官方商城:中国手机市场出货量第一品牌
2017/10/18 全球购物
百度吧主申请感言
2014/01/12 职场文书
医院我们的节日活动实施方案
2014/08/22 职场文书
高校群众路线教育实践活动剖析材料
2014/10/10 职场文书
商业门面租房协议书
2014/11/25 职场文书
2015年公司工作总结
2015/04/25 职场文书
浪漫的婚礼主持词
2015/06/30 职场文书
三八妇女节主持词
2015/07/04 职场文书
你对自己的信用报告有过了解吗?
2019/07/09 职场文书
微信小程序 WeUI扩展组件库的入门教程
2022/04/21 Javascript