解决vant中tab栏遇到的坑van-tabs
话不多说,先看下问题描述:
我的需求:(和头条的tab栏类似 ,单击查看头条tab栏)
点击tab栏,下⽅展⽰出来当前tab栏下的内容列表(A页⾯),点击列表进⼊详情内容(B页⾯),但是返回(A页⾯)的时候,需要显⽰刚才被点击的tab栏⾼亮显⽰。(如果tab栏横向有滚动条,那也得让被选中的⾼亮显⽰)。
所以,⼤部分⼈的解决办法就是将当前选中的tab的索引缓存起来,等回到该页⾯的时候,让被缓存的那个⾼亮显⽰出来。
坑的问题在于:van-tabs,⾥⾯的v-model默认值是0,但是类型却写着 number | string 。
image
但是,在此时⽤缓存赋值给 v-model = " active " 的时候,active的值需要是number类型,才有效,否则再怎么设置都是⽆效的。
【代码放⼊项⽬可直接执⾏】
<pre class="brush:xhtml;" Courier New", monospace; text-decoration: none; outline: none !important; outline-offset: 0px !important; box-sizing: border-box; margin: 0px 0px 10px; padding: 9.5px; overflow: auto; font-size: 13px; color: rgb(51, 51, 51); background: rgb(245, 245, 245); line-height: 1.42857; display: block; word-break: break-all; overflow-wrap: break-word; border: 1px solid rgb(204, 204, 204); border-radius: 4px;"><template>
<div>
htmlborder<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></pre>
<pre class="brush:js;" Courier New", monospace; text-decoration: none; outline: none !important; outline-offset: 0px !important; box-sizing: border-box; margin: 0px 0px 10px; padding: 9.5px; overflow: auto; font-size: 13px; color: rgb(51, 51, 51); background: rgb(245, 245, 245); line-height: 1.42857; display: block; word-break: break-all; overflow-wrap: break-word; border: 1px solid rgb(204, 204, 204); border-radius: 4px;"><script>
export default{
data(){
return{
active: Item("activeIdx"))?Item("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></pre>
最终的效果图是这样的,和头条的tab栏的效果是⼀样的。点击查看 头条tab效果
image
补充知识:****vue移动端框架van-sticky粘性布局,实现原理和失效原因及注意点
说到粘性布局,我们最常见的就算在app tab选项卡随页⾯滚动到顶部后悬停在那,看效果
image
要实现这个效果,最简单的办法就是在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.$height.offsetHeight,经测试能准确达到固定的位置,
如果各位有其他好办法,请在下⾯留⾔,⼤家⼀起学习。
以上这篇解决vant中 tab栏遇到的坑 van-tabs就是⼩编分享给⼤家的全部内容了,希望能给⼤家⼀个参考,也希望⼤家多多⽀持云海天教程。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。