1.需要在mainfest.json plus對象里添加
"statusbar": { "immersed": "true", "style":"dark" }
2.新建immersed.js
注意 在里邊不適用plus,因為plus.ready之后再js改變樣式 必然造成頁面閃爍跳動
(function(w){ document.addEventListener('plusready',function(){ //console.log("Immersed-UserAgent: "+navigator.userAgent); },false); var immersed = 0; var ms=(/Html5Plus\/.+\s\(.*(Immersed\/(\d+\.?\d*).*)\)/gi).exec(navigator.userAgent); if(ms&&ms.length>=3){ immersed=parseFloat(ms[2]); } w.immersed=immersed; if(!immersed){ return; } var t=document.getElementsByClassName('mui-bar-nav')[0]; t&&(t.style.height=(t.offsetHeight+immersed-t.style.paddingTop)+'px',t.style.paddingTop=immersed+'px'); var tt=document.getElementsByClassName('mui-content')[0]; tt&&t&&(tt.style.marginTop=(tt.style.marginTop+immersed)+'px'); })(window);
這兒需要注意的是 h5+的api也可以獲取 例如
使用5+API 判斷當前環境是否支持沉浸式狀態欄 plus.navigator.isImmersedStatusbar() 如果當前支持沉浸式狀態欄則返回true,否則返回false。 獲取當前系統狀態欄高度 plus.navigator.getStatusbarHeight() 獲取系統狀態欄高度,Number類型。 其單位是邏輯像素值,即css中可直接使用的像素值,可能存在小數點。
但是由於時機問題還是推薦拿正則判斷,然后在需要的頁面引入此js即可