最近作的項目涉及相應的頁面顯示相應的頂部標題,因此就須要自定義頭部導航了。android
首先新建一個頂部導航公用組件topnav,導航高度怎麼計算?json
1.wx.getSystemInfo 和 wx.getSystemInfoSync 獲取機器信息 2.screenHeight - windowHeight 計算標題欄高度 3.標題欄高度 'iPhone': 64, 'iPhone X': 88, 'android': 68
app.js小程序
//app.js App({ onLaunch: function () { var that = this wx.getSystemInfo({ success: function (res) { that.globalData.platform = res.platform let totalTopHeight = 68 if (res.model.indexOf('iPhone X') !== -1) { totalTopHeight = 88 } else if (res.model.indexOf('iPhone') !== -1) { totalTopHeight = 64 } that.globalData.statusBarHeight = res.statusBarHeight that.globalData.titleBarHeight = totalTopHeight - res.statusBarHeight }, failure() { that.globalData.statusBarHeight = 0 that.globalData.titleBarHeight = 0 } }) })
還需更改配置app.json微信小程序
"window": { "backgroundTextStyle": "light", "navigationBarBackgroundColor": "#15ae67", "navigationBarTitleText": "微信小程序", "navigationBarTextStyle": "white", "navigationStyle": "custom" //自定義導航欄配置 }
topnav.wxml微信
<!--template.wxml--> <!-- 這是自定義組件的內部WXML結構 --> <view style="padding-top:{{someData.statusBarHeight+someData.titleBarHeight}}px"> <view class="hh-header"> <view class="status-bar" style="height:{{someData.statusBarHeight}}px"></view> <view class="title-bar" style="height:{{someData.titleBarHeight}}px"> <view wx:if="{{isShowBack=='true'}}" class='hh-nav-back ico-back' bindtap='goback'></view> <view wx:if="{{isShowBack=='false'}}" class='hh-nav-back'></view> <view class="hh-title">{{innerTitle}}</view> <view class="hh-nav-right"></view> </view> </view> </view> <slot></slot>
topnav.jsonapp
{ "component": true }
topnav.jsxss
const app = getApp() Component({ properties: { // 這裏定義了innerText屬性,屬性值能夠在組件使用時指定 innerTitle: { type: String, value: '頭部標題' }, isShowBack: { type: String, value: "true" } }, data: { // 這裏是一些組件內部數據 someData: { statusBarHeight: app.globalData.statusBarHeight, titleBarHeight: app.globalData.titleBarHeight } }, methods: { // 這裏是一個自定義方法 goback: function () { wx.navigateBack({ delta: 1, }) } } })
topnav.wxssflex
.ico-back{ width: 36rpx; height: 36rpx; background-size: contain; background-image: url(); background-repeat: no-repeat; background-position-x: 20rpx; } .hh-header { position: fixed; top: 0; width: 100%; background-color: #14ae66; z-index: 99; } .hh-title{ font-size: 38rpx; text-align: center; color: #fff; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .title-bar { display: flex; justify-content: space-between; align-items: center; } .hh-nav-right{ width: 116px; } .hh-nav-back{ width: 116px; }
這樣組件就寫好了 只須要在你每一個頁面裏面用這個組件傳不一樣的值就能夠了。ui
index.wxmlthis
<component-topnav inner-title="{{title}}"></component-topnav> //顯示返回按鈕
index.js
//獲取應用實例 const app = getApp() Page({ data: { motto: 'Hello World', userInfo: {}, title:'自定義導航標題' }, })
index.json
{ "usingComponents": { "component-topnav": "/pages/component/topnav" } }