混合開發 h5+ 沉浸式的適配


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即可

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM