小程序如何自定义tabbar组件,实现底部tab切换
时间:2021-08-24
来源:互联网
标签:
今天PHP爱好者给大家带来本篇文章给大家介绍一下在小程序页面中自定义tabbar组件,实现底部tab切换的方法。希望对大家有所帮助。

近日需求,设计稿如图

要实现一个特殊的底部导航栏,采用官方提供的自定义tabbar组件,添加底部tab页面,切换图片闪屏。
解决采用swiper轮播图+自定义组件
1.编写自定义组件jtab-bar
wxml文件
<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>
js文件
Component({
data: {
selected: 0,
color: "#999999",
selectedColor: "#032F82",
list: [
{
type: 'text',
text: "首页"
},
{
type: 'image',
icon: '../../image/icon_map.png',
iconSelect: '../../image/icon_map_select.png',
text: ''
},
{
type: 'text',
text: "我的"
}]
},
attached() {
},
methods: {
switchTab(e) {
const data = e.currentTarget.dataset
this.setData({selected: data.index})
this.triggerEvent("setTab", data.index)
}
}
})
wxss文件
.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文件
<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文件
.jswipper-block {
height: calc(100vh - 170rpx);
background: #F7F8F9;
}
js文件
/**
* 页面的初始数据
*/
data: {
background: ['demo-text-1', 'demo-text-2', 'demo-text-3'],
currentTab: 0
},
setTabbar({detail}) {
this.setData({currentTab: detail})
},
// 轮播图 禁止手动滑动 catchtouchmove="swipperStop"
swipperStop(){
},
暂完。
以上就是小程序如何自定义tabbar组件,实现底部tab切换的详细内容,更多请关注php爱好者其它相关文章!
-
电脑中远程访问功能怎么删除?删除远程访问功能详细步骤(电脑中远程访问怎么弄) 时间:2025-11-04 -
win7本地ip地址怎么设置?win7设置本地ip地址操作步骤(win7本机ip地址在哪里) 时间:2025-11-04 -
电脑中任务管理器被禁用怎么处理?任务管理器被禁用的详细解决方案(电脑中任务管理器显示内存如何释放) 时间:2025-11-04 -
2023年中央空调十大品牌选购指南 家用商用高性价比推荐排行 时间:2025-09-28 -
免费装扮QQ空间详细教程 手把手教你打造个性化空间不花钱 时间:2025-09-28 -
中国数字资产交易平台官网 - 安全可靠的数字货币交易与投资首选平台 时间:2025-09-28
今日更新
-
币安欧易自动续借理财设置教程 轻松开启智能收益
阅读:18
-
揭秘什么大蛇梗:全网爆火的蛇类表情包源头竟是这个
阅读:18
-
币安与欧易现货交易量对比:谁更具市场优势
阅读:18
-
币安vs欧易:DeFi Staking年化收益率大比拼
阅读:18
-
"什么大师是什么梗"是网络热词,指网友调侃某些领域自称专家却漏洞百出的搞笑现象,通常用于幽默反讽。
阅读:18
-
币安与欧易Web3钱包私钥备份功能对比:哪家更便捷安全
阅读:18
-
健身教练什么大是什么梗 揭秘网络爆火身材梗的真相与教程
阅读:18
-
使命召唤手游CODM创作者怎么报名--创作者报名方法
阅读:18
-
星痕共鸣新活动日历发布-幻华流月之野副本即将开放
阅读:18
-
币安欧易官方认证KOL有哪些 社区权威指南
阅读:18










