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

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

image.png

在code實(shí)現(xiàn)之前先敲黑板(了解一下需要的知識點(diǎ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)欄高度}
具體實(shí)現(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)系作者
  • 序言:七十年代末药有,一起剝皮案震驚了整個濱河市臀晃,隨后出現(xiàn)的幾起案子窗轩,更是在濱河造成了極大的恐慌夯秃,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,406評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件痢艺,死亡現(xiàn)場離奇詭異仓洼,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)堤舒,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評論 3 393
  • 文/潘曉璐 我一進(jìn)店門色建,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人舌缤,你說我怎么就攤上這事箕戳∧巢校” “怎么了?”我有些...
    開封第一講書人閱讀 163,711評論 0 353
  • 文/不壞的土叔 我叫張陵陵吸,是天一觀的道長玻墅。 經(jīng)常有香客問我,道長壮虫,這世上最難降的妖魔是什么澳厢? 我笑而不...
    開封第一講書人閱讀 58,380評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮囚似,結(jié)果婚禮上剩拢,老公的妹妹穿的比我還像新娘。我一直安慰自己饶唤,他們只是感情好徐伐,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,432評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著搬素,像睡著了一般呵晨。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上熬尺,一...
    開封第一講書人閱讀 51,301評論 1 301
  • 那天摸屠,我揣著相機(jī)與錄音,去河邊找鬼粱哼。 笑死季二,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的揭措。 我是一名探鬼主播胯舷,決...
    沈念sama閱讀 40,145評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼绊含!你這毒婦竟也來了桑嘶?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,008評論 0 276
  • 序言:老撾萬榮一對情侶失蹤躬充,失蹤者是張志新(化名)和其女友劉穎逃顶,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體充甚,經(jīng)...
    沈念sama閱讀 45,443評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡以政,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,649評論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了伴找。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片盈蛮。...
    茶點(diǎn)故事閱讀 39,795評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖技矮,靈堂內(nèi)的尸體忽然破棺而出抖誉,到底是詐尸還是另有隱情殊轴,我是刑警寧澤,帶...
    沈念sama閱讀 35,501評論 5 345
  • 正文 年R本政府宣布寸五,位于F島的核電站梳凛,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏梳杏。R本人自食惡果不足惜韧拒,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,119評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望十性。 院中可真熱鬧叛溢,春花似錦、人聲如沸劲适。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽霞势。三九已至烹植,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間愕贡,已是汗流浹背草雕。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留固以,地道東北人墩虹。 一個月前我還...
    沈念sama閱讀 47,899評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像憨琳,于是被迫代替她去往敵國和親诫钓。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,724評論 2 354

推薦閱讀更多精彩內(nèi)容