小程序app.js文件中判斷獲取當(dāng)前設(shè)備機(jī)型,如果是iphoneX系列機(jī)型,那么設(shè)計(jì)到底部時(shí),則考慮設(shè)置底部按鈕或選項(xiàng)卡的margin-bottom、padding-bottom、height等,或者添加一個(gè)div來(lái)占位小黑條的位置。
1 使用wx.getSystemInfoSync()中的screenHeight和safeArea對(duì)象的bottom屬性判斷
這里使用screenHeight是獲取屏幕的高度,因?yàn)閎ottom是以屏幕左上角為原點(diǎn)開(kāi)始計(jì)算的,所以需要的是屏幕高度,對(duì)比screenHeight和safeArea,如果相等則說(shuō)明不需要適配,不相等則需要適配。
`const isIPhoneX = () => {
let screenHeight = wx.getSystemInfoSync().screenHeight
let bottom = wx.getSystemInfoSync().safeArea.bottom
return screenHeight !== bottom
}`
底部選項(xiàng)卡或吸底元素樣式判斷
<view class=" {{isIPhoneX ? 'marginB' : ''}}">底部選項(xiàng)卡或吸底元素</view>
而env()和constant()函數(shù)有個(gè)必要的使用前提,H5網(wǎng)頁(yè)設(shè)置viewport-fit=cover的時(shí)候才生效,小程序里的viewport-fit默認(rèn)是cover
解決方案
`.detailBotoom{
position: fixed;
bottom: 0;
width: 100%;
display: flex;
height: calc(96rpx+ constant(safe-area-inset-bottom));/// 兼容 IOS<11.2 /
height: calc(96rpx + env(safe-area-inset-bottom));/// 兼容 IOS>11.2 /
background: #fff;
border-top: 1rpx solid #eaeef1;
z-index: 99;
padding-bottom: constant(safe-area-inset-bottom);/// 兼容 IOS<11.2 /
padding-bottom: env(safe-area-inset-bottom);/// 兼容 IOS>11.2 /
}`