当前位置: 首页 > 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等状态库来管理激活状态和通讯事件。码字不易,如有不对地方,请提出指正;如有帮助,还望三连。

http://www.lqws.cn/news/503623.html

相关文章:

  • MediaMarktSaturn EDI 对接指南:欧洲零售卖场的数字化协同范例
  • 火山引擎向量数据库 Milvus 版正式开放
  • 竹云受邀出席华为开发者大会,与华为联合发布海外政务数字化解决方案
  • 【MATLAB代码】基于MVC的EKF和经典EKF对三维非线性状态的滤波,提供滤波值对比、误差对比,应对跳变的观测噪声进行优化
  • 安全报告:LLM 模型在无显性攻击提示下的越狱行为分析
  • SSE和Kafka应用场景对比
  • taro小程序,tailwindcss的bg-x-x,背景颜色不生效,只有自定义的写法颜色才生效
  • Qt面试题汇总
  • 在微服务中使用 Sentinel
  • PYTHON从入门到实践3-变量
  • LayUI的table实现行上传图片+mvc
  • JavaEE初阶第四期:解锁多线程,从 “单车道” 到 “高速公路” 的编程升级(二)
  • 在 .NET Core WebAPI 项目中,执行文件(.exe)方式运行并指定端口
  • Python实例题:Web 爬虫与数据可视化
  • 《AI大模型核心技术揭秘与商业落地实战》学习内容系统总结
  • Android APP内切换语言无感重启到当前界面
  • Jenkins+Jmeter+Ant接口持续集成
  • 6.24_JAVA_微服务_Elasticsearch搜索
  • Temporal Join,一探究竟
  • 【服务器】教程 — Linux上如何挂载服务器NAS
  • GitHub Actions 的深度解析与概念介绍
  • 智能制造——解读基于AI框架的智能工厂设计思路【附全文阅读】
  • 【论文阅读 | CVPRW 2023 |CSSA :基于通道切换和空间注意力的多模态目标检测】
  • CSS 实现文本溢出省略号(三种主流方式,适配单行 多行)
  • PHP 华为云H5上传文件:临时链接上传文件和POST表单直传
  • 华为云Flexus+DeepSeek征文|基于华为云Flexus Dify复用优秀 AI Agent 应用教程
  • Elasticsearch | 索引和模板字段管理:增加新字段的详细操作
  • 《C++初阶之类和对象》【初始化列表 + 自定义类型转换 + static成员】
  • React性能优化精髓之一:频繁setState导致滚动卡顿的解决方案
  • Jmeter接口自动化测试框架