vant中 tab栏遇到的坑 van-tabs。
话不多说,先看下问题描述:我的需求:点击tab栏,下方展示出来当前tab栏下的内容列表(A页面),点击列表进入详情内容(B页面),但是返回(A页面)的时候,需要显示刚才被点击的tablan高亮显示。(如果tab栏横向有滚动条,那也得让被选中的高亮显示)。所以,大部分人的解决办法就是将当前选中的tab的索引缓存起来,等回到该页面的时候,让被缓存的那个高亮显示出来。坑的问题在于:van-tabs,里面
·
话不多说,先看下问题描述:
我的需求:(和头条的tab栏类似 ,单击查看头条tab栏)
点击tab栏,下方展示出来当前tab栏下的内容列表(A页面),点击列表进入详情内容(B页面),但是返回(A页面)的时候,需要显示刚才被点击的tab栏高亮显示。(如果tab栏横向有滚动条,那也得让被选中的高亮显示)。
所以,大部分人的解决办法就是将当前选中的tab的索引缓存起来,等回到该页面的时候,让被缓存的那个高亮显示出来。
坑的问题在于:van-tabs,里面的v-model默认值是0,但是类型却写着 number | string 。

但是,在此时用缓存赋值给 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效果

更多推荐



所有评论(0)