微信小程序(uniapp)自定義導(dǎo)航欄

想要實現(xiàn)自定義導(dǎo)航欄效果圖如下

image.png

在code實現(xiàn)之前先敲黑板(了解一下需要的知識點)
image.png

由圖我們可以看出 \color{red}{整體高度 = 狀態(tài)欄高度 + 導(dǎo)航欄高度}
\color{red}{狀態(tài)欄高度}可以通過 \color{red}{wx.getSystemInfo()}獲取,現(xiàn)在就只用解決導(dǎo)航欄的高度了
觀察發(fā)現(xiàn),膠囊頂部高度距離航欄頂部高度的高度差 和 膠囊底部高度距導(dǎo)航欄底部高度的高度差 是一樣的,也就是說 \color{red}{導(dǎo)航欄的高度 = 膠囊高度 + (高度差) X 2 }
\color{red}{膠囊信息}可以通過 \color{red}{wx.getMenuButtonBoundingClientRect()}獲取,現(xiàn)在就只用解決高度差了
\color{red}{wx.getMenuButtonBoundingClientRect()} 中也返回了膠囊頂部距屏幕頂部距離的信息(top)
所以知 \color{red}{高度差 = 膠囊頂部距屏幕頂部距離 - 狀態(tài)欄高度}
具體實現(xiàn):
1.先在pages.json中設(shè)置 navigationStyle 為 custom

image.png

  1. js 獲取相關(guān)數(shù)據(jù)
// 獲取導(dǎo)航欄的高度
export const computedNavHeight = () => {
    // #ifdef MP-WEIXIN
    if (wx.canIUse('getMenuButtonBoundingClientRect')) {
        let sysInfo = wx.getSystemInfoSync();
        //狀態(tài)欄的高度
        let statusBarHeight = sysInfo.statusBarHeight;
        // 膠囊位置信息
        let rect = wx.getMenuButtonBoundingClientRect();
        let menuButtonRect = JSON.parse(JSON.stringify(rect));
        // 導(dǎo)航欄高度
        let navBarHeight = (rect.top - sysInfo.statusBarHeight) * 2 + rect.height;
        // 自定義導(dǎo)航欄的高度
        let height = (statusBarHeight + navBarHeight);
        return {
            statusBarHeight,
            menuButtonRect,
            navBarHeight,
            height
        }
    } else {
        wx.showToast({
            title: '您的微信版本過低,界面可能會顯示不正常',
            icon: 'none',
            duration: 4000
        });
    }
    // #endif
}
  1. html 設(shè)置相關(guān)

    由于js方法是封裝好的,所以需要在js里先引入在使用
    image.png

    image.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容