本篇文章给大家介绍一下在小程序页面中自定义tabbar组件,实现底部tab切换的方法。
近日需求,设计稿如图
要实现一个特殊的底部导航栏,采用官方提供的自定义tabbar组件,添加底部tab页面,切换图片闪屏。
解决采用swiper轮播图+自定义组件
1.编写自定义组件jtab-bar
wxml文件
1 2 3 4 5 6 7 | <view class= "jtab-bar" >
<view class= "jtab-bar-item" wx: for = "{{list}}" wx:key= "index" data-index= "{{index}}" bindtap= "switchTab" >
<image wx: if = "{{item.type === 'image'}}" class= "jcover-img-bigicon"
src= "{{selected === index ? item.iconSelect : item.icon}}" ></image>
<view class= "jtab-text" wx: else style= "color: {{selected === index ? selectedColor : color}}" >{{item.text}}</view>
</view>
</view>
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 | Component({
data: {
selected: 0,
color: "#999999" ,
selectedColor: "#032F82" ,
list: [
{
type: & #39;text',
text: "首页"
},
{
type: & #39;image',
icon: & #39;../../image/icon_map.png',
iconSelect: & #39;../../image/icon_map_select.png',
text: & #39;'
},
{
type: & #39;text',
text: "我的"
}]
},
attached() {
},
methods: {
switchTab(e) {
const data = e.currentTarget.dataset
this .setData({selected: data.index})
this .triggerEvent( "setTab" , data.index)
}
}
})
|
wxss文件
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | .jtab-bar {
position: fixed;
bottom: 0;
left: 0;
right: 0;
height: 100rpx;
background: white;
display: flex;
align-items: center;
padding-bottom: env(safe-area-inset-bottom);
box-shadow: 0px -2rpx 2rpx rgba(153, 153, 153, 0.1);
}
.jtab-bar-item {
text-align: center;
flex: 1;
height: 100rpx;
}
.jtab-bar-item .jtab-text {
height: 100rpx;
line-height: 100rpx;
}
.jcover-img-bigicon {
position: fixed;
bottom: 0rpx;
width: 210rpx;
height: 128rpx;
padding-bottom: env(safe-area-inset-bottom);
margin: 0 auto;
right: 0;
left: 0;
}
|
使用的两张图片:
2.页面中使用
wxml文件
1 2 3 4 5 6 7 8 9 10 | <view>
<swiper class= "jswipper-block" current= "{{currentTab}}" duration= "{{100}}" >
<block wx: for = "{{background}}" wx:key= "*this" >
<swiper-item catchtouchmove= "swipperStop" >
<view class= "swiper-item {{item}}" >{{item}}</view>
</swiper-item>
</block>
</swiper>
<jtabbar bindsetTab= "setTabbar" />
</view>
|
这里使用catchtouchmove="swipperStop" swipperStop是个空函数来处理,禁止手动滑动
wxss文件
1 2 3 4 | .jswipper-block {
height: calc(100vh - 170rpx);
background: #F7F8F9;
}
|
js文件
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
data: {
background: [& #39;demo-text-1', 'demo-text-2', 'demo-text-3'],
currentTab: 0
},
setTabbar({detail}) {
this .setData({currentTab: detail})
},
swipperStop(){
},
|
暂完。
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
暂时没有评论,来抢沙发吧~