解决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 相关文章推荐
用javascript实现的支持lrc歌词的播放器
May 17 Javascript
jquery text,radio,checkbox,select操作实现代码
Jul 09 Javascript
jQuery不间断滚动效果(模拟百度新闻支持文字/图片/垂直滚动)
Feb 05 Javascript
利用jquery动画特效和css打造的侧边弹出垂直导航
Apr 04 Javascript
基于jquery的文字向上跑动类似跑马灯的效果
Sep 22 Javascript
jQuery中scrollLeft()方法用法实例
Jan 16 Javascript
AngularJs Understanding the Controller Component
Sep 02 Javascript
Angular中实现树形结构视图实例代码
May 05 Javascript
vue+elementUI实现表单和图片上传及验证功能示例
May 14 Javascript
tweenjs缓动算法的使用实例分析
Aug 26 Javascript
vue中nextTick用法实例
Sep 11 Javascript
JavaScript ECMA-262-3 深入解析(一):执行上下文实例分析
Apr 25 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
dedecms中显示数字验证码的修改方法
2007/03/21 PHP
ThinkPHP3.1的Widget新用法
2014/06/19 PHP
ThinkPHP实现二级循环读取的方法
2014/11/03 PHP
用javascript实现读取txt文档的脚本
2007/07/20 Javascript
JQUERY操作JSON实例代码
2010/02/09 Javascript
javascript 解决表单仍然提交即使监听处理函数返回false
2010/03/14 Javascript
js调用css属性写法
2013/09/21 Javascript
jquery实现手机发送验证码的倒计时代码
2014/02/12 Javascript
浏览器窗口加载和大小改变事件示例
2014/02/27 Javascript
JS+CSS实现另类带提示效果的竖向导航菜单
2015/10/15 Javascript
checkbox 选中一个另一个checkbox也会选中的实现代码
2016/07/09 Javascript
JavaScript数据操作_浅谈原始值和引用值的操作本质
2016/08/23 Javascript
jQuery中animate()的使用方法及解决$(”body“).animate({“scrollTop”:top})不被Firefox支持的问题
2017/04/04 jQuery
微信小程序 判断手机号的实现代码
2017/04/19 Javascript
JS ES6多行字符串与连接字符串的表示方法
2017/04/26 Javascript
D3.js进阶系列之CSV表格文件的读取详解
2017/06/06 Javascript
create-react-app 修改为多入口编译的方法
2018/08/01 Javascript
Jquery+AJAX实现无刷新上传并重命名文件操作示例【PHP后台接收】
2020/05/29 jQuery
基于ant design日期控件使用_仅月份的操作
2020/10/27 Javascript
详解Python程序与服务器连接的WSGI接口
2015/04/29 Python
idea创建springMVC框架和配置小文件的教程图解
2018/09/18 Python
使用Scrapy爬取动态数据
2018/10/21 Python
浅谈python 导入模块和解决文件句柄找不到问题
2018/12/15 Python
python 图像插值 最近邻、双线性、双三次实例
2020/07/05 Python
如何验证python安装成功
2020/07/06 Python
python 装饰器的使用示例
2020/10/10 Python
欧洲高端品牌直销店:Fashionesta
2016/08/31 全球购物
Sunglasses Shop德国站:欧洲排名第一的太阳镜网站
2017/08/01 全球购物
锐步美国官方网站:Reebok美国
2018/01/10 全球购物
lululemon美国官网:瑜伽服+跑步装备
2018/11/16 全球购物
效能风暴心得体会
2014/09/04 职场文书
七年级思品教学反思
2016/02/20 职场文书
用Python爬虫破解滑动验证码的案例解析
2021/05/06 Python
Python 处理表格进行成绩排序的操作代码
2021/07/26 Python
Go语言的协程上下文的几个方法和用法
2022/04/11 Golang