uniapp自定义头部(兼容微信小程序(胶囊和状态栏),兼容h5)

很早之前就写过自定义头部,但是那时偷懒写死了,现在用插槽重新写了个

有两种形式:
type1是完全自定义的,可以自己去组件改也可以用插槽改
type2是正常的返回标题和右边按钮,使用就是 title="标题" @rightClick = "函数",右边按钮是插槽,可以和下面例子一样用

效果图

类型1

类型2 的h5

类型2的小程序

使用

javascript 复制代码
<myHead title="首页" type="2">
	<view slot="right">
		<text>提交</text>
	</view>
</myHead>

组件代码

javascript 复制代码
<template>
	<view class="myHead">
		<!-- myHead的占位 -->
		<view class="myHead_placeholder" :style="{
				height: addUnit(height + statusBarHeight,'px')
			}">
		</view>
		<view class="myHead_fixed" :style="{'paddingRight': capsuleWidth + 'px'}">
			<!-- 状态栏 -->
			<view class="status_bar" :style="{
				height: addUnit(statusBarHeight)
			}"></view>
			<!-- 头部本体 -->
			<slot>
				<view v-if="type == 1" class="myHead_content" :style="{
					height: addUnit(height)
				}">
					<image src="/static/img/logo.png"></image>
					<text>为牛只-屠宰全产业护航{{capsuleWidth}}</text>
				</view>
				<view v-else class="myHead_content2" :style="{
					height: addUnit(height)
				}">
					<view class="left" @click="leftClick">
						<text class="iconfont icon-left"></text>
					</view>
					<view class="content">
						{{title}}
					</view>
					<view class="right" @click="rightClick">
						<text>提交</text>
					</view>
				</view>
			</slot>
		</view>
	</view>
</template>

<script>
	export default {
		name: "myHead",
		props: {
			// 点击左侧区域(返回图标),是否自动返回上一页
			autoBack: {
				type: Boolean,
				default: false
			},
			title: {
				type: String | Number,
				default: '标题'
			},
			type: {
				type: String | Number,
				default: 2
			}
		},
		data() {
			return {
				// 状态栏
				statusBarHeight: 0,
				// 头部本体高度
				height: 44,
				// 如果有胶囊
				capsuleWidth: 0
			};
		},
		mounted() {
			// 手机状态栏的高度
			this.statusBarHeight = uni.getSystemInfoSync().statusBarHeight || 0
			this.getNavBarHeight()
		},
		methods: {
			// 获取胶囊宽度
			getNavBarHeight() {
				// 小程序环境
				// #ifdef MP-WEIXIN
				const menuButtonInfo = uni.getMenuButtonBoundingClientRect();
				uni.getSystemInfo({
					success: (systemInfo) => {
						this.capsuleWidth = menuButtonInfo.width + systemInfo.screenWidth - menuButtonInfo
							.right; // 胶囊宽度
					}
				})
				// #endif
				// #ifdef H5
				this.capsuleWidth = 0
				// #endif
			},
			addUnit(num, unit = 'px') {
				return num + unit
			},
			// 点击左侧区域
			leftClick() {
				// 如果配置了autoBack,自动返回上一页
				this.$emit('leftClick')
				if (this.autoBack) {
					uni.navigateBack()
				}
			},
			// 点击右侧区域
			rightClick() {
				this.$emit('rightClick')
			},
		}
	}
</script>

<style lang="scss" scoped>
	.myHead {
		.myHead_placeholder {
			width: 100%;
		}

		.myHead_fixed {
			position: fixed;
			left: 0;
			right: 0;
			top: 0;
			z-index: 11;

			.myHead_content {
				display: flex;
				align-items: center;

				image {
					width: 150rpx;
					margin-right: 10rpx;
				}

				text {
					font-size: 24rpx;
					color: rgba(29, 37, 65, 0.5);
				}
			}

			.myHead_content2 {
				display: flex;
				align-items: center;
				justify-content: space-between;
				padding: 0 20rpx;

				.left {
					font-size: 28rpx;
				}

				.content {
					flex: 1;
					text-align: center;
					font-size: 32rpx;
				}

				.right {
					font-size: 28rpx;
				}
			}
		}
	}
</style>
相关推荐
2501_9159090610 小时前
全面解析前端开发中常用的浏览器调试工具及其使用场景
android·ios·小程序·https·uni-app·iphone·webview
wuxianda103010 小时前
uniapp项目上架苹果商店4.3a被拒,3天极速解决方案2026.5.8
前端·人工智能·flutter·uni-app·ios上架·苹果上架·苹果4.3a
云起SAAS13 小时前
企业名片画册相册微信小程序源码 | 管理后台+后端 | 含产品展示资讯视频
微信小程序·广告联盟·企业名片画册相册微信小程序源码
px不是xp15 小时前
Docker部署Qdrant向量数据库,初始化向量数据库,重构RAG逻辑
数据库·docker·微信小程序·重构·qdrant
小盼江16 小时前
Uniapp小程序鲜花商城推荐系统 买家卖家双端(web+uniapp)
前端·小程序·uni-app
px不是xp16 小时前
【灶台导航】 RAG系统的容错设计:从向量搜索到关键词降级,一个都不能少
javascript·微信小程序·notepad++·rag
阿里巴啦16 小时前
微信小程序实战:基于原生框架 + 云开发实现 干饭足迹小程序,美食打卡、地图探索与消费报告
微信小程序·小程序开发·微信云开发·云函数·小程序项目实战·美食打卡记录
fakaifa16 小时前
【最新版】CRMEB Pro版v4.0系统源码 全开源+uniapp/PC前端+搭建教程
uni-app·开源·商城小程序·crmeb·crmebpro
px不是xp18 小时前
【灶台导航】烹饪导航页:步骤、定时器与语音播报
前端·javascript·微信小程序·云函数
空中海1 天前
微信小程序 - 03 工程实践层与综合 Demo
微信小程序·小程序·notepad++