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

我的需求:(和头条的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效果

Logo

有“AI”的1024 = 2048,欢迎大家加入2048 AI社区

更多推荐