赞
踩
话不多说,先看下问题描述:
我的需求:(和头条的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效果
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。