当前位置: 首页 > news >正文

轻量级小程序自定义tabbar组件封装的实现与使用

一、前言。

众所周知,原生tabBar是相对固定的配置方式,样式布局单一,无法满足日益丰富的tabbar效果。所以,掌握自定义tabbar的组件封装就变得重中之重。本文就基于uni-app来简述如何封装和使用轻量级的小程序自定义tabbar组件。

二、工具准备。

因为是基于uni-app开发的小程序,所以在准备封装自定义tarbar组件前,我们需要准备以下工具和素材。

  • HBuilderX
  • 微信开发者功能
  • tarbar的基础配置
  • 自定义tabbar的基础组件

三、开发流程。

  1. pages.json文件tabbar的配置。

虽然是自定义tabbar,但是也需在pages.json中定义tabbar的配置,这里配置上我们需要的tabbar项即可。

  1. cc-myTabbar基础tarbar组件的导入。

将 ext.dcloud.net.cn/plugin?id=1… 中的基础tabbar插件下载并导入至我们项目中即可。

  1. 对自定义组件cc-myTabbar的改造,按需改造成我们想要的tabbar布局和样式。
  • ui效果图:

  • 代码改造(.vue):
<template><view class="tabbar_box"><view class="tabbar_list"><view class="tabbar_list_item" @tap.stop="onTabBar(0)"><image mode="scaleToFill":src="tabBarShow == 0 ? '/static/images/tabbar_home_blue.png' : '/static/images/tabbar_home_gray.png'"></image><text :class="tabBarShow == 0 ? 'tabbar_list_item_blue' : 'tabbar_list_item_gray'">首页</text></view><view class="tabbar_list_opera" @tap.stop="initiateScan"><image src="/static/images/tabbar_sys_blue.png" mode="scaleToFill"></image></view><view class="tabbar_list_item" @tap.stop="onTabBar(1)"><image mode="scaleToFill":src="tabBarShow == 1 ? '/static/images/tabbar_my_blue.png' : '/static/images/tabbar_my_gray.png'"></image><text :class="tabBarShow == 1 ? 'tabbar_list_item_blue' : 'tabbar_list_item_gray'">我的</text></view></view></view>
</template><script>export default {data() {return {};},props: {tabBarShow: {type: Number,default: 0,}},mounted() {},methods: {//点击tabbaronTabBar(index) {switch (index) {case 0:uni.switchTab({url: '/pages/home/index'})break;case 1:uni.switchTab({url: '/pages/personal/index'})break;}},//扫一扫initiateScan(){this.$emit('tabBarScan')}}}
</script><style scoped lang="scss">@import 'cc-myTabbar.scss';
</style>
  • 代码改造(.scss):
.tabbar_box{position: fixed;left: 0;bottom: 0;width: 100%;height: 140rpx;z-index: 9999;background: #FFFFFF;box-shadow: 0rpx 6rpx 24rpx 0rpx rgba(192,200,220,0.5);border-radius: 0rpx 0rpx 0rpx 0rpx;border: 2rpx solid;border-image: linear-gradient(360deg, rgba(241.26902639865875, 243.61616045236588, 248.31042855978012, 1), rgba(255, 255, 255, 1)) 2 2;.tabbar_list{display: flex;justify-content: space-between;align-items: center;width: 100%;height: 100%;background-color: #FFFFFF;.tabbar_list_item{display: flex;flex-direction: column;align-items: center;width: 33%;image{width: 50rpx;height: 50rpx;								}.tabbar_list_item_blue{font-weight: 500;font-size: 30rpx;color: #3CC0FF;padding-top: 6rpx;}.tabbar_list_item_gray{font-weight: 500;font-size: 30rpx;color: rgba(0, 0, 0, .3);padding-top: 6rpx;}}.tabbar_list_opera{display: flex;justify-content: center;align-items: center;width: 33%;image{width: 120rpx;height: 120rpx;}}}
}
  1. 自定义tabbar组件的使用。

在需要tabbar的页面底部引入并使用即可(这里的页面需与步骤1中pages.json的tabbar中配置的页面一致)。

  1. 效果图。

四、要点、重点说明。

  1. 自定义tabbar组件中的页面必须与pages.json的tabbar中配置的页面一致。

  1. 自定义tabbat组件中无跳转页面的功能按钮(如:扫一扫)需定义通讯事件。

五、结语。

以上就是实现轻量级的小程序自定义tabbar组件封装和使用全过程,能实现大多数情况的tabbar组件布局和样式。当然,如果项目比较大,需要页面和要素较多,可以引用vuex、pinna等状态库来管理激活状态和通讯事件。码字不易,如有不对地方,请提出指正;如有帮助,还望三连。

相关文章:

  • 找人做一下网站大概多少钱深圳百度代理
  • 做母婴网站赚钱怎么注册一个网站
  • shopex网站 css乱了谷歌关键词搜索
  • 疯狗做网站cnfg二级域名免费分发
  • 苏州新区网站建设广州新闻播报
  • 国内精美网站欣赏重庆森林电影
  • 做上门私厨/上门做饭App小程序,到底是定制开发,还是选成品系统?
  • 域名 SSL证书和IP SSL证书有什么区别?
  • JVM堆(Heap)详解与工作流程分析
  • Dify与代理商奇墨科技为企业定制AI应用开发专属方案,适配多样化业务需求
  • 如何将短信从 Android 传输到计算机
  • Sentinel的流控策略
  • prometheus+grafana+Linux监控
  • RAG实战 第四章:RAG 检索增强技术与优化
  • Hive decimal类型详解
  • 技术解析:基于x264与FFmpeg的视频高效压缩策略——以小丸工具箱类GUI工具为例
  • vue.js 3: markmap using typescript
  • maven:迁移到 Maven Central 后 pom.xml的配置步骤
  • 【云计算】云测试
  • OSS跨区域复制灾备方案:华东1到华南1的数据同步与故障切换演练
  • Java模块打包格式与多版本JAR详解
  • 深度解析:2D写实数字人交互场景的创新与应用
  • IDC报告AR/VR市场反弹Meta份额超半,谷歌/微美全息精准卡位AR/AI眼镜市场机遇
  • Unity3D下的RTSP/RTMP超低延迟直播播放器实践:跨平台、高性能与VR全景支持的完整解析
  • 如何为虚拟机上的 Manjaro Linux启用 VMware 拖放功能
  • RAG实战 第三章:知识库构建与管理