【uni-app】自定义导航栏/标题栏

前言

  • Hbuilder X 2.7.14.20200618

什么是自定义导航栏

默认导航栏或原生导航栏是啥样的,你懂的。

但,我想给导航栏加个背景图,比如这样:
在这里插入图片描述
我想给导航栏背景设置成渐变,比如这样:
在这里插入图片描述
这时候就需要自定义导航栏。

自定义导航栏

自定义导航栏的中心思想是:

  1. 取消默认导航栏或原生导航栏。
  2. 自定义导航栏,并放置到正确位置。

取消默认导航栏或原生导航栏

取消默认导航栏或原生导航栏有两个方式:

  1. 全局取消原生导航栏
  2. 单页面取消原生导航栏

全局取消原生导航栏

在 pages.json 的 globalStyle 里有个 navigationStyle 配置项,默认是default。navigationStyle=default 时,所有页面均为原生导航栏;navigationStyle=custom时,所有页面都没有原生导航栏。

...
"globalStyle": {
	...
    "navigationStyle": "custom",
    ...
},
...

单页面取消原生导航栏

在 pages.json 的 pages 配置项下每个页面均有个 navigationStyle 配置项,默认是default。navigationStyle=default 时,该页面均为原生导航栏;navigationStyle=custom时,该页面都没有原生导航栏。

...
"pages": [ 
		{
		    "path" : "pages/index/index",
		    "style" : {
		    	"navigationBarTitleText" : "首页",
				"navigationStyle":"custom",
				...
		    }
		},
		...
],
...

取消原生导航栏后是这样的

取消原生导航栏后,页面顶部直通状态栏区域。
由于窗体为沉浸式,因此页面占据了状态栏位置,导致页面顶部直通状态栏区域。

注意:在微信小程序里,右上角始的胶囊按钮不受取消原生导航栏设置的影响

自定义导航栏

自定义导航栏可以理解为出现在原生导航栏区域的页面元素。

假设要在导航栏中添加LOGO,实现如下效果:
在这里插入图片描述

  1. 在 pages.json 的 pages 配置项下, 修改 pages/index/index 页面的配置如下:
"pages": [
	{
		"path": "pages/index/index",
		"style": {
			"navigationBarTitleText": "uni-app",
			"navigationStyle":"custom"
		}
	}
],
  1. pages/index/index 代码为
<template>
	<view>
		<!-- 自定义导航栏 -->
		<view class="navBarBox">
			<!-- 状态栏占位 -->
			<view class="statusBar" :style="{ paddingTop: statusBarHeight + 'px' }"></view>
			<!-- 真正的导航栏内容 -->
			<view class="navBar">
				<image class="logo" src="/static/logo.png" mode="scaleToFill"></image>
				<view>我是导航栏标题</view>
			</view>
		</view>
		<!-- 页面内容 -->
		<view>我是页面内容</view>
	</view>
</template>

<script>
	export default {
		data() {
			return {
				// 状态栏高度
				statusBarHeight: 0,
				// 导航栏高度
				navBarHeight: 82+11,
			};
		},
		props: {
			
		},
		//第一次加载时调用
		created() {
			//获取手机状态栏高度
			this.statusBarHeight = uni.getSystemInfoSync()['statusBarHeight'];
		},
	}
</script>

<style>
.navBarBox{}
.navBarBox .statusBar {}
.navBarBox .navBar {
	padding: 3rpx 50rpx;
	padding-bottom: 8rpx;
	display: flex;
	flex-direction: row;
	justify-content: center;
	align-items: center;
}
.navBarBox .navBar .logo {
	width: 82rpx;
	height: 82rpx;
	margin-right: 10rpx;
}
</style>

说明:

  • 页面加载后,计算导航栏高度。
  • 得到状态栏高度后,将状态栏高度赋值给状态栏占位元素。这样就空出了状态栏。注意状态栏的单位为px,其它地方使用的单位为rpx。
  • 导航栏中放置一个image元素,用于展示LOGO。再放一个view元素,用于展示标题。
  1. 运行到小程序模拟器,得到前面想要的效果。

自定义导航栏组件

在uni-app插件市场搜索导航栏插件,可以轻松实现自定义导航栏。
如果找不到合适的,可以按照前面的步骤自己编写。

  • 23
    点赞
  • 107
    收藏
    觉得还不错? 一键收藏
  • 12
    评论
Uniapp中可以通过使用自定义组件来实现自定义顶部导航栏。以下是一个简单的示例: 1. 在Uniapp项目中创建一个自定义组件,例如命名为"custom-nav"。 2. 在"custom-nav"组件中添加一个顶部导航栏的布局,例如: ```html <template> <view class="nav-wrapper"> <view class="nav-left"> <!-- 左侧按钮 --> </view> <view class="nav-title"> {{ title }} </view> <view class="nav-right"> <!-- 右侧按钮 --> </view> </view> </template> <style> .nav-wrapper { display: flex; justify-content: space-between; align-items: center; height: 44px; background-color: #fff; border-bottom: 1px solid #eee; } .nav-left, .nav-right { width: 50px; height: 100%; display: flex; justify-content: center; align-items: center; } .nav-title { flex: 1; text-align: center; font-size: 16px; font-weight: bold; } </style> ``` 3. 在父组件中使用"custom-nav"组件,并在"custom-nav"组件中传递标题和按钮等参数,例如: ```html <template> <view class="container"> <custom-nav title="自定义导航栏" :showLeftButton="true" :showRightButton="true" /> <!-- 页面内容 --> </view> </template> <script> import CustomNav from '@/components/custom-nav/index.vue'; export default { components: { CustomNav } } </script> <style> .container { padding-top: 44px; /* 需要加上导航栏高度 */ } </style> ``` 4. 在"custom-nav"组件中通过props接收父组件传递的参数,并在模板中根据参数来显示或隐藏左右按钮等,例如: ```html <template> <view class="nav-wrapper"> <view class="nav-left" v-if="showLeftButton"> <!-- 左侧按钮 --> </view> <view class="nav-title"> {{ title }} </view> <view class="nav-right" v-if="showRightButton"> <!-- 右侧按钮 --> </view> </view> </template> <script> export default { props: { title: { type: String, default: '' }, showLeftButton: { type: Boolean, default: false }, showRightButton: { type: Boolean, default: false } } } </script> ``` 这样就可以在Uniapp中实现自定义顶部导航栏了。
评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值