微信小程序 —— 自定义顶部、底部导航栏以及获取胶囊体位置信息。


theme: smartblue

highlight: a11y-dark

coversdfasd.png

一、前言

我们在进行微信小程序开发时,常常需要自定义一些东西,比如自定义顶部导航自定义底部导航等等。那么知道这些自定义内容的具体位置、以及如何适配不同的机型就变得尤为重要。下面让我以在iPhone机型,来给大家介绍下微信小程序如何获取自定义内容的位置信息。

二、开启自定义

如果需要自定义顶部和底部导航。那么如何在自定义后能够适配不同的机型而不会出现样式问题呢?我们可以通过wx.getSystemInfo({})方法来获取页面的信息来保证样式的正确性。此方法常用于app.js文件中的onLanch()方法中,保证这些信息优先被加载,并把获取到的页面信息放到全局变量中,方便其他页面的获取使用。

在此之前需要开启自定义顶部和底部导航栏。如下所示:

javascript { "pages": [ "pages/index/index", "pages/index2/index2" ], //自定义顶部导航 "navigationStyle": "custom", "window": { "navigationStyle": "custom", "navigationBarTextStyle": "white", "backgroundTextStyle": "light" }, //自定义底部导航 "navigationStyle": "custom",这里注意在设置自定义底部导航栏时,list中至少包含两个页面 "tabBar": { "custom": true, "list": [ { "pagePath": "pages/index/index", "text": "首页" }, { "pagePath": "pages/index2/index2", "text": "首页2" } ] }, "style": "v2", "sitemapLocation": "sitemap.json" }

2.1 整个页面

1.位置

Snipaste_2023-08-09_13-59-59.png

2.如何获取

页面代码:

html <view style="height: {{screenHeight}}px;background-color: aliceblue;"> </view>

页面js代码:

```javascript const app = getApp() Page({ data: { screenHeight: app.globalData.screenHeight, } })

```

app.js文件代码:

```javascript

onLaunch: function() {
    wx.getSystemInfo({
        success: e => {
            //获取整个页面的高度
            this.globalData.screenHeight = e.screenHeight;
          }
         },
    )}

```

2.1 状态栏

1.位置

状态栏就是手机最顶部显示时间信号电量等信息的区域。一般状态栏的信息我们不单独获取设置,因为顶部导航栏包含了状态栏

Snipaste_2023-08-09_14-01-35.png

2.如何获取

页面代码:

```html

```

页面js代码:

javascript // index.js const app = getApp() Page({ data: { screenHeight: app.globalData.screenHeight, statusBarHeight: app.globalData.statusBarHeight } })

app.js文件代码:

javascript onLaunch: function() { wx.getSystemInfo({ success: e => { this.globalData.screenHeight = e.screenHeight; //获取状态栏的高度 this.globalData.StatusBar = e.statusBarHeight; } }, )}

2.2 顶部导航栏

1.位置

顶部导航栏的高度是包含胶囊体的。

Snipaste_2023-08-09_14-03-03.png

2.如何获取

首先获取胶囊体的信息,如果不存在胶囊体,顶部导航栏高度 = 状态栏高度 + 50;如果存在顶部导航栏高度 = 胶囊体离页面顶部的距离 + 胶囊体离页面底部的距离 - 状态栏高度 页面代码:

```html

```

页面js代码:

```javascript const app = getApp() Page({ data: { screenHeight: app.globalData.screenHeight, customBar: app.globalData.CustomBar } })

```

app.js代码:

```javascript // app.js App({ globalData:{ }, onLaunch: function() { wx.getSystemInfo({ success: e => { let capsule = wx.getMenuButtonBoundingClientRect(); if (capsule) { this.globalData.Custom = capsule; this.globalData.CustomBar = capsule.bottom + capsule.top - e.statusBarHeight; } else { this.globalData.CustomBar = e.statusBarHeight + 50; } } }, )} })

```

2.4 内容区域

1.位置

如果你做的小程序没有底部导航栏的话,那么内容区域 = 页面总高度 - 顶部导航栏高度

Snipaste_2023-08-09_14-04-26.png

但是如果你需要底部导航的话那么内容区域 = 页面总高度 - 顶部导航栏高度 - 底部导航栏高度

Snipaste_2023-08-09_14-05-17.png

2.如何获取

页面代码:

javascript <view style="height:{{screenHeight}}px;width: 100%;background-color: rgb(255, 255, 255);"> <!--顶部导航栏--> <view class="" style="height: {{CustomBar}}px;background-color: blue;"></view> <!--内容区域--> <view class="" style="height: {{screenHeight - CustomBar}}px;background-color: black;"></view> <!--内容区域 包含底部导航--> <view class="" style="height: {{screenHeight - CustomBar - tabBarHeight}}px;background-color: black;"></view> </view>

页面js代码:

javascript const app = getApp() Page({ data: { screenHeight: app.globalData.screenHeight, CustomBar: app.globalData.CustomBar, tabBarHeight: app.globalData.tabBarHeight, } })

app.js代码:

```javascript // app.js App({ globalData:{

}, onLaunch: function() { // 获取系统状态栏信息 wx.getSystemInfo({ success: e => { this.globalData.screenHeight = e.screenHeight; this.globalData.tabBarHeight = e.screenHeight - e.safeArea.bottom + 50 let capsule = wx.getMenuButtonBoundingClientRect(); if (capsule) { this.globalData.CustomBar = capsule.bottom + capsule.top - e.statusBarHeight; } else { this.globalData.CustomBar = e.statusBarHeight + 50; } } }, )} })

```

2.3 底部导航栏

1.位置

Snipaste_2023-08-09_14-06-40.png

2.如何获取

页面代码:

```html

```

页面js代码:

javascript const app = getApp() Page({ data: { screenHeight: app.globalData.screenHeight, statusBarHeight: app.globalData.statusBarHeight, customBar: app.globalData.CustomBar, tabBar: app.globalData.tabBarHeight, tabBarHeight: app.globalData.tabBarHeight } })

app.js代码:

javascript onLaunch: function() { wx.getSystemInfo({ success: e => { this.globalData.screenHeight = e.screenHeight; this.globalData.tabBarHeight = e.screenHeight-e.safeArea.bottom + 50 let capsule = wx.getMenuButtonBoundingClientRect(); if (capsule) { this.globalData.Custom = capsule; this.globalData.CustomBar = capsule.bottom + capsule.top - e.statusBarHeight; } else { this.globalData.CustomBar = e.statusBarHeight + 50; } } }, )}

这个底部导航栏之所以+50,我是从小程序框架中获取的,可以直接拿来用。

三、胶囊体

3.1 什么是胶囊体?

image.png

我们再做自定义顶部导航时,在一些场景下需要在导航中设置返回按钮以及其他信息:

image.png

返回按钮和信息需要和胶囊体对齐才完美,所以我们需要获取到胶囊体的位置信息。

3.2 如何获取?

```javascript // app.js App({ globalData:{ }, onLaunch: function() { // 获取系统状态栏信息 wx.getSystemInfo({ success: e => { //胶囊体距离顶部距离 this.globalData.capsuleTop = wx.getMenuButtonBoundingClientRect().top; //胶囊体的高度 this.globalData.capsuleHeight = wx.getMenuButtonBoundingClientRect().height; //胶囊体的宽度 this.globalData.capsuleWidth = wx.getMenuButtonBoundingClientRect().width; } }, wx.onKeyboardHeightChange((res) => { console.log('键盘高度111111:', res.height) wx.setStorageSync('keyBordHeight', res.height) }) )} })

```

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

是江迪呀

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值