首页 小程序 总结-微信小程序自定义顶部导航(超详细)附加效果图

总结-微信小程序自定义顶部导航(超详细)附加效果图

一、在需要设置头部导航栏的页面中通过json配置 "navigationStyle":"custom" ,自定义导航栏,只保留胶囊按钮,效果如下:

二、做完上面的步骤,基本上就可以自定义导航栏了,当然,这还没完,从页面上可以看出,页面里的内容被挡住了,可以通过页面样式加上内边距内容就出来了:

三、可以看出这个内边距是固定死了的,不同的手机型号头部那条栏目高度可能不一致,所以为了我们适配更多型号,我们需要计算3个值:

1. 整个导航栏的高度;

2. 胶囊按钮与顶部的距离;

3. 胶囊按钮与右侧的距离。

小程序可以通过wx.getMenuButtonBoundingClientRect()获取胶囊按钮的信息 和wx.getSystemInfo()获取设备信息:

通过这些信息我们可以计算出上面说的3个值:

1. 整个导航栏高度 = statausBarHeight + >

3.胶囊按钮与右侧的距离 = windowWidth - right

四、App.js 添加代码如下:

  1. // app.js
  2. App({
  3. // 定义一个全区对象用于保存一些设备及胶囊的数据, 在其他页面onLoad之后可以通过
  4. // const App = getApp(), App.globalData. 的方式访问到
  5. globalData: {},
  6. onLaunch() {
  7. // 获取胶囊信息
  8. let menuButtonObject = wx.getMenuButtonBoundingClientRect()
  9. console.log(menuButtonObject)
  10. // 获取设备信息
  11. wx.getSystemInfo({
  12. success: res => {
  13. console.log(res)
  14. // 整个导航栏的高度
  15. let navHeight = menuButtonObject.top + menuButtonObject.>
    // 导航栏的高度
  16. let nav = navHeight - res.statusBarHeight
  17. // 挂载到全区变量 globalData 上
  18. this.globalData.navHeight = navHeight
  19. this.globalData.nav = nav
  20. // 胶囊与左边的距离
  21. this.globalData.menuLeft = menuButtonObject.left
  22. // 胶囊的高度
  23. this.globalData.menuHeight = menuButtonObject.>
    // 胶囊距离顶部的高度
  24. this.globalData.menuBot = menuButtonObject.top - res.statusBarHeight
  25. // 整个设备的宽度
  26. this.globalData.windowWidth = res.windowWidth
  27. },
  28. fail: err => {
  29. console.log(err)
  30. }
  31. })
  32. // 展示本地存储能力
  33. const logs = wx.getStorageSync('logs') || []
  34. logs.unshift(Date.now())
  35. wx.setStorageSync('logs', logs)
  36. // 登录
  37. wx.login({
  38. success: res => {
  39. // 发送 res.code 到后台换取 openId, sessionKey, unionId
  40. }
  41. })
  42. },
  43. globalData: {
  44. userInfo: null
  45. }
  46. })

五、可以自定义导航栏样式了:

特别声明:本站部分内容收集于互联网是出于更直观传递信息的目的。该内容版权归原作者所有,并不代表本站赞同其观点和对其真实性负责。如该内容涉及任何第三方合法权利,请及时与824310991@qq.com联系,我们会及时反馈并处理完毕。