效果图
data:image/s3,"s3://crabby-images/517fa/517fa267df8330fac898eb2cdcdf8cca2c4470e6" alt=""
data:image/s3,"s3://crabby-images/25fd4/25fd453917f495bd072a91cd67f84ec1da6d2ccc" alt=""
1.pages.js,需要自定义导航栏的页面设置"navigationStyle": "custom"
data:image/s3,"s3://crabby-images/e7c5b/e7c5b7301630a2c1496154225a217d549c2c43cf" alt=""
2.App.vue,获取设备高度及胶囊位置
javascript
onLaunch: function () {
// 系统信息
const systemInfo = uni.getSystemInfoSync()
// 胶囊按钮位置信息
const menuButtonInfo = uni.getMenuButtonBoundingClientRect()
this.globalData.navBarInfo = {
statusBarHeight: systemInfo.statusBarHeight,
top: menuButtonInfo.top,
height: menuButtonInfo.height,
paddingTop: menuButtonInfo.top + menuButtonInfo.height + menuButtonInfo.top - systemInfo.statusBarHeight,
windowHeight: systemInfo.windowHeight
};
},
3.在需要的地方设置导航栏高度
html
<template>
<view class="customNav" :style="{ ...styleClass, opacity: opacity, backgroundColor: bgcolorString }">
<slot></slot>
</view>
</template>
javascript
const state = reactive({
styleClass: {
paddingTop: '60px',
height: '32px',
}
})
onShow(() => {
const navBarInfo = getApp().globalData.navBarInfo
state.styleClass = {
paddingTop: navBarInfo.statusBarHeight + 'px',
height: (navBarInfo.top - navBarInfo.statusBarHeight) * 2 + navBarInfo.height + 'px',
}
})
data:image/s3,"s3://crabby-images/c2bf6/c2bf60daf06ffad9cf95c359b63a6c14d99f2293" alt=""