lanan-app/components/VNavigationBar.vue

92 lines
1.8 KiB
Vue
Raw Normal View History

2024-08-21 20:13:21 +08:00
<template>
2025-08-29 17:13:05 +08:00
<!-- header -->
<view :style="{ backgroundColor, paddingTop: homeHeaderPaddingTop + 'px', height: homeHeaderMenuHeight + 'px' }"
class="navigationBar">
<uni-icons @click="back" class="navigationBarBack" size="24" type="left" :color="titleColor"></uni-icons>
<view class="navigationBarTitle" :style="{ color: titleColor }">
{{ title }}
</view>
2024-08-22 19:34:47 +08:00
<view class="navigationBarBackExtra">
2025-08-29 17:13:05 +08:00
<slot name="extra">
</slot?>
2024-08-22 19:34:47 +08:00
</view>
2025-08-29 17:13:05 +08:00
</view>
2024-08-21 20:13:21 +08:00
</template>
<script>
2025-08-29 17:13:05 +08:00
/* 计算标题位置 */
import {
getWXStatusHeight
} from "@/utils/utils";
2024-08-21 20:13:21 +08:00
2025-08-29 17:13:05 +08:00
export default {
props: {
backgroundColor: {
type: String,
default: '#317DFA'
},
title: String,
titleColor: {
type: String,
default: '#fff'
}
2024-08-21 20:13:21 +08:00
},
2025-08-29 17:13:05 +08:00
mounted() {
2024-08-21 20:13:21 +08:00
// #ifdef MP
2025-08-29 17:13:05 +08:00
const {
barHeight,
barTop,
menuButtonLeft
} = getWXStatusHeight()
console.log('barHeight, barTop, menuButtonLeft: ', barHeight, barTop, menuButtonLeft);
this.homeHeaderPaddingTop = barTop || 0
this.homeHeaderMenuHeight = barHeight
this.homeHeaderMenuLeft = menuButtonLeft - 6
2024-08-21 20:13:21 +08:00
// #endif
2025-08-29 17:13:05 +08:00
},
data() {
return {
// #ifdef MP
homeHeaderPaddingTop: 0,
homeHeaderMenuHeight: 0,
homeHeaderMenuLeft: 0,
// #endif
// #ifdef APP || H5
homeHeaderPaddingTop: 50,
homeHeaderMenuHeight: 50,
homeHeaderMenuLeft: 0
// #endif
}
},
methods: {
back() {
uni.navigateBack({
delta: 1,
})
}
2024-08-21 20:13:21 +08:00
}
}
</script>
<style lang="scss" scoped>
2025-08-29 17:13:05 +08:00
.navigationBar {
position: relative;
display: flex;
align-items: center;
justify-content: center;
.navigationBarBack {
position: absolute;
left: 20rpx;
}
.navigationBarBackExtra {
position: absolute;
right: 20rpx;
}
.navigationBarTitle {
font-size: 32rpx;
}
2024-08-22 19:34:47 +08:00
}
2024-08-21 20:13:21 +08:00
</style>