uniapp 开发小程序之实现不同身份展示不同的 tabbar(底部导航栏),附带相关问题解答

news2024/11/17 14:24:16

效果展示:

 

引言

在开发过程中逐渐意识到uniapp原生的tabbar可能不能满足开发要求,通过浏览博客才选择使用uView的Tabbar 底部导航栏来实现,我选择用的是2X版本

安装

我是使用Hbuilder插件的方式引入的组件库,安装配置可以看这篇:

下载安装方式配置 | uView 2.0 - 全面兼容nvue的uni-app生态框架 - uni-app UI框架

插件市场:

uView2.0重磅发布,利剑出鞘,一统江湖 - DCloud 插件市场

现在就开始现实需求

  • 首先在pages.json中定义文件路径:
"pages": [{
			"path": "pages/xxx/xxx",
			"style": {
				"navigationBarTitleText": "",
				"enablePullDownRefresh": false
			}

		},
		{
			//消息
			"path": "pages/xxx/xxx"
		},
		{
			"path": "pages/xxx/xxx",
			"style": {
				"navigationBarTitleText": "xxxx"
			}

		},

		{
			"path": "pages/xxx/xxx",
			"style": {
				"navigationBarTitleText": "",
				"enablePullDownRefresh": false
			}
		},
        {
         xxxxxxxxxxxxxxxxxxxxxx 
         }]
	"tabBar": {
		"height":"1px",
		// 配置选中颜色
		"selectedColor": "#22bf8e",
		"color": "#f8f8f8", // 设置为与背景颜色相同
		"backgroundColor": "transparent", // 设置为透明
		// list 每一项
		"list": [{
				"pagePath": "pages/xxx/xxx"
			},
			{
				"pagePath": "pages/xxx/xxx"
			},
			{
				"pagePath": "pages/xxx/xxx"
			},
			{
				"pagePath": "pages/xxx/xxx"
			},
			{
				"pagePath": "xxxxxxxxxxxxxx"
			}
		]
	}

配置pages.josn中tabBar的原因:是因为要根据uni.switchTab来跳转页面,而uni.switchTab能够跳转是需要在tabBar中定义pagePath的

tabbar底部栏过多怎么办:pages.josn中tabBar最多只能定义五个,如果超出就不能使用uni.switchTab跳转了,需要用uni.switchTab跳转,不过这两种跳转的效果是不同的,具体需要按照实际情况

  • 然后定义一个tabbar.js
//身份一
let tab1 = [{
		"text": "消息",
		"pagePath": "pages/xxx/xxx",
		"iconPath": "../static/xxx/xxx",
		"selectedIconPath": "../static/xxx/xxx"
	},
	{
		"text": "消息",
		"pagePath": "pages/xxx/xxx",
		"iconPath": "../static/xxx/xxx",
		"selectedIconPath": "../static/xxx/xxx"
	},
	{
		"text": "消息",
		"pagePath": "pages/xxx/xxx",
		"iconPath": "../static/xxx/xxx",
		"selectedIconPath": "../static/xxx/xxx"
	},
	{
		"text": "消息",
		"pagePath": "pages/xxx/xxx",
		"iconPath": "../static/xxx/xxx",
		"selectedIconPath": "../static/xxx/xxx"
	}
]
// 身份二
let tab2 = [{
		"text": "消息",
		"pagePath": "pages/xxx/xxx",
		"iconPath": "../static/xxx/xxx",
		"selectedIconPath": "../static/xxx/xxx"
	},
	{
		"text": "消息",
		"pagePath": "pages/xxx/xxx",
		"iconPath": "../static/xxx/xxx",
		"selectedIconPath": "../static/xxx/xxx"
	},
	{
		"text": "消息",
		"pagePath": "pages/xxx/xxx",
		"iconPath": "../static/xxx/xxx",
		"selectedIconPath": "../static/xxx/xxx"
	},
	{
		"text": "消息",
		"pagePath": "pages/xxx/xxx",
		"iconPath": "../static/xxx/xxx",
		"selectedIconPath": "../static/xxx/xxx"
	}
]
export default [
	tab1,
	tab2
]
  • 然后在app.vue中登录,根据身份进行判断赋值,localStorage.set()我是封装的uni.setStorageSync方法
import tabBar from '@/utils/tabbar.js'

if(xxxx){
localStorage.set('tabBar', tabBar[0])
}else if(xxx){
localStorage.set('tabBar', tabBar[1])
}
  • 然后在app.vue中隐藏掉原生tabbar
onLaunch: function() {
			uni.hideTabBar()
			console.log('App onLaunch')
		},
onShow: function() {
			uni.hideTabBar()
			console.log('App Show')
		}
  • 然后定义一个tabbar组件
<template>
	<view>
		<u-tabbar class="tabbar-ios-fix" activeColor='#22bf8e' :value="current?current:0" :fixed="true"
			:placeholder="true" :safeAreaInsetBottom="true" @change="handleTabClick">
			<u-tabbar-item v-for='(item,index) in tabList' :key="index" :text="item.text">
				<image slot="inactive-icon" class="u-page__item__slot-icon" :src="item.iconPath">
				</image>
				<image slot="active-icon" class="u-page__item__slot-icon" :src="item.selectedIconPath">
				</image>
			</u-tabbar-item>
		</u-tabbar>
	</view>
</template>

<script>
	import localStorage from '@/utils/localStorage.js'
	export default {
		props: {
			current: Number
		},
		data() {
			return {
				tabList: localStorage.get('tabBar')
			};
		},
		mounted() {
			console.log(this.tabList)
		},
		methods: {
			handleTabClick(index) {
				console.log(index)
				if (index >= 3) {
					console.log('切换到我的')
					switch (index) {
						case 3:
							uni.navigateTo({
								url: '/pages/mine/mine',
							});
							break;
					}
					return
				}
				// 使用 uni.switchTab 方法切换页面
				uni.switchTab({
					url: '/' + this.tabList[index].pagePath,
				});

			},
		}
	}
</script>

<style lang="scss">
	.u-page__item__slot-icon {
		width: 50rpx;
		height: 50rpx;
	}

	.tabbar-ios-fix {
		bottom: calc(120rpx + env(safe-area-inset-bottom));
	}
</style>

u-tabbar解惑:

一、如需要自定义图标/颜色,在u-tabbar-item标签中使用插槽active-iconinactive-icon来定义图标和颜色

二、可以通过.u-page__item__slot-icon修改图标大小

三、不在pages.josn中定义list,可通过switch判断,用uni.navigateTo跳转

四、其他属性可查看官网:

Tabbar 底部导航栏 | uView 2.0 - 全面兼容nvue的uni-app生态框架 - uni-app UI框架

  • 然后开始使用tabbar组件 ,正常引用、注册、使用就行
<tabbar :current="0"></tabbar>




import tabbar from "@/components/tabbar.vue"
export default {
		components: {
			tabbar
	}
}

注意:哪里需要底部栏,就在哪几个页面引入、注册、使用


其中遇到一个机型问题,苹果手机预览,底部还是会出现一段白底,如何解决?

其实也很简单,在每个使用了tabbar组件的页面中也单独定义隐藏原生tabbar的方法,如下代码

onLoad() {
			uni.hideTabBar()
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/700366.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

CVE-2023-34541 LangChain 任意命令执行

漏洞简介 LangChain是一个用于开发由语言模型驱动的应用程序的框架。 在LangChain受影响版本中&#xff0c;由于load_prompt函数加载提示文件时未对加载内容进行安全过滤&#xff0c;攻击者可通过构造包含恶意命令的提示文件&#xff0c;诱导用户加载该文件&#xff0c;即可造成…

单片机学习 14-DS18B20温度传感器实验

DS18B20 温度传感器实验 ​ 本次实验我们来学习精度较高的外部 DS18B20 数字温度传感器&#xff0c;由于此传感器是单总线接口&#xff0c;所以需要使用 51 单片机的一个 IO 口模拟单总线时序与 DS18B20 通信&#xff0c;将检测的环境温度读取出来。开发板上集成了 1 个 DS18B…

createdTime(new Date()) 数据库时间比实际多八小时

本来是createdTime&#xff08;new Date&#xff08;&#xff09;&#xff09;&#xff0c;一次生成两条数据 一直正常&#xff0c;今天却多八小时 一开始往new Date&#xff08;&#xff09;差八个小时的问题上找&#xff0c; 网上说要 在apprication.yml文件中配置一下数据…

大佬详细讲解:银行核心项目之测试阶段

最近有小伙伴留言说「想了解核心系统建设中&#xff0c;冒烟、SIT、UAT、回归测试的重点&#xff0c;如何设计测试案例&#xff0c;或相关的资料推荐等」。 这个话题很笼统&#xff0c;测试这一块儿除了业务测试&#xff0c;还有性能测试、安全测试等&#xff1b;以及不同的角…

解决pyecharts图表在jupyter notebook无法显示的问题

在jupyter notebook尝试制作pyecharts图表&#xff0c;遇到无法显示的问题&#xff0c;网上查到的结果有各种不同原因&#xff0c;此处一一罗列&#xff0c;便于大家排查并彻底解决问题。 情况1&#xff1a;图表完全无法显示 解决方案&#xff1a;参考此文档 注&#xff1a;…

web自动化测试——xpath和css语法详解(五)

目录 1.css选择器 1.1什么是css选择器&#xff1f; 1.2css选择器语法 2.xpath 1.什么是xpath&#xff1f; 2.什么是XML? 3.XML与HTML 4.节点的概念 5.XPath &#x1f381;更多干货 完整版文档下载方式&#xff1a; 1.css选择器 1.1什么是css选择器&#xff1…

SmaAt-UNet github

来源 SmaAt-UNet github SmaAt-UNet&#xff1a; 使用小型关注网结构的降水预报 论文链接 安装依赖 这个项目使用poetry作为依赖性管理。因此&#xff0c;安装所需的依赖项就像这样简单&#xff1a; conda create --name smaat-unet python3.9 conda activate smaat-unet p…

基于Java学生宿舍管理设计实现(源码+lw+部署文档+讲解等)

博主介绍&#xff1a;✌全网粉丝30W,csdn特邀作者、博客专家、CSDN新星计划导师、Java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专…

正负压自动控制技术在离体肺通气系统中的应用

摘要&#xff1a;模拟肺呼吸过程的离体肺通气控制新方法——真空压力&#xff08;正负压&#xff09;法&#xff0c;目前还停留在理论层面的文献报道&#xff0c;还未见到这种方法的仪器化内容和细节。本文基于这种新方法提出了仪器化实现的具体解决方案&#xff0c;解决方案的…

闲置iPad Pro打造真正的生产力工具!使用vscode编程写代码

文章目录 前言视频教程1. 本地环境配置2. 内网穿透2.1 安装cpolar内网穿透(支持一键自动安装脚本)2.2 创建HTTP隧道 3. 测试远程访问4. 配置固定二级子域名4.1 保留二级子域名4.2 配置二级子域名 5. 测试使用固定二级子域名远程访问6. iPad通过软件远程vscode6.1 创建TCP隧道 7…

Windows电脑玩游戏出现白屏的解决方法

逢年过节玩游戏&#xff0c;周末放假玩游戏&#xff0c;休闲娱乐玩游戏…玩游戏成了不少电脑用户的小乐趣。但是有时候在玩游戏的过程中&#xff0c;会遇到一些令人头疼的问题&#xff0c;比如游戏突然白屏&#xff0c;无法正常进行。这种情况可能会影响游戏体验&#xff0c;甚…

Recurdyn导入x_t格式装配体

装配层次结构&#xff1a;选上表示导入的装配体包括子装配体&#xff0c;再勾选body或者subsystem表示子装配体以零件或者子系统显示在recurdyn中&#xff1b;不选&#xff0c;表示导入的装配体全部以零件显示。

如何修改 Linux 的时区

文章结构 一、查看 Linux 当前时区二、获取时区 TZ 值&#xff08;可选做&#xff09;三、配置 TZ 值四、加载配置并检验是否生效 TZ 是 time zone 的缩写&#xff01; 一、查看 Linux 当前时区 你可以使用如下命令非常容易地就查看到 Linux 系统的当前时区&#xff1a; # 查…

AE插件:能量激光描边光效特效Saber Mac

Saber Mac插件主要用于AE软件中创造制作&#xff1a;能量光束&#xff0c;光剑&#xff0c;激光&#xff0c;传送门&#xff0c;霓虹灯&#xff0c;闪电&#xff0c;电流&#xff0c;朦胧等特效&#xff0c;插件操作直观简单&#xff0c;含有25种不同类型的特效预设&#xff08…

【sql注入-WAF绕过】编写sqlmap的tamper进行sql注入

目录 编写sqlmap的绕过脚本 二、理论知识2 sqlmap的tamper脚本 三、实战部分 一、理论知识1 编写sqlmap的绕过脚本 编写sqlmap的一个简单WAF绕过脚本 #!/usr/bin/env python""" Copyright (c) 2006-2023 sqlmap developers (https://sqlmap.org/) See th…

网络安全合规-银行业数据治理架构体系搭建(二)

本次《指引》使用了许多新兴词汇&#xff0c;这些词汇均是首次被监管部门正式引用&#xff0c;并出现在银行业金融机构的监督管理文件中。我们将通过这些词汇更好地理解《指引》。 首席数据官&#xff1a;“首席数据官”首次作为需要监管机构任职资格许可的管理岗位被提出。通过…

Cortex-M内核知识点总结

总览 Cortex内核 基础 寄存器组 程序在经过编译后&#xff0c;生成可执行二进制文件&#xff0c;如上图&#xff0c;是截取某个函数在flash中存储的内容 (反汇编文件)可以看到以下信息&#xff1a; 指令的存储地址 &#xff0c;指令的二进制内容 &#xff0c; 指令代表的汇编类…

MyBatis—环境配置

MyBatis &#x1f50e;MyBatis 的定义&#x1f50e;MyBatis 的环境配置添加依赖链接数据库配置 MyBatis 中的 XML 路径 一些人习惯将 MyBatis 称为 iBatis MyBatis → iBatis(Plus 版) &#x1f50e;MyBatis 的定义 MyBatis 是⼀款优秀的持久层框架, 它⽀持⾃定义 SQL、存储过…

基于 FFmpeg 的跨平台视频播放器简明教程(四):像素格式与格式转换

系列文章目录 基于 FFmpeg 的跨平台视频播放器简明教程&#xff08;一&#xff09;&#xff1a;FFMPEG Conan 环境集成基于 FFmpeg 的跨平台视频播放器简明教程&#xff08;二&#xff09;&#xff1a;基础知识和解封装&#xff08;demux&#xff09;基于 FFmpeg 的跨平台视频…

5G NR:RACH随机接入过程

1. 简述 无论是3G,4G还是现在的5G都需要随机接入过程&#xff0c;随机接入过程主要是为了让基站和UE之间做好上行同步以及初始接入。此文章仅仅帮助大家了解此过程&#xff0c;更加具体的用途及其场景需要参考具体的3GPP协议&#xff08;38.211,38.212,38.213).主要帮助理解如下…