当前位置:   article > 正文

vant中 tab栏遇到的坑 van-tabs。_va-tab

va-tab

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

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

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

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

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

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

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

  1. <template>
  2. <div>
  3. <van-tabs v-model="active"
  4. @click="tabHandler"
  5. :ellipsis="false"
  6. :border="false"
  7. >
  8. <van-tab v-for="(tabname,idx) in tabList" :key="idx" :title="tabname"></van-tab>
  9. </van-tabs>
  10. <van-button @click="toDetailHandler">去详情页</van-button>
  11. </div>
  12. </template>
  13. <script>
  14. export default{
  15. data(){
  16. return{
  17. active: Number(localStorage.getItem('activeIdx'))?Number(localStorage.getItem('activeIdx')):0,
  18. tabList:['111111','2222222','3333333','44444444','55555','666666','7777777','88888','999999999'],
  19. }
  20. },
  21. methods:{
  22. // tab点击事件
  23. tabHandler(idx){
  24. this.active = idx;
  25. localStorage.setItem('activeIdx',idx) // 将选中的tab缓存起来
  26. },
  27. // 去详情页
  28. toDetailHandler(){
  29. this.$router.push('/tab1')
  30. }
  31. }
  32. }
  33. </script>

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

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号