沉浸式导航栏html,混合开发 h5+ 沉浸式的适配

本文介绍了如何在manifest.jsonplus中配置实现沉浸式状态栏,并提供了JavaScript代码示例,用于动态调整页面元素以适配沉浸式状态栏。同时提到了使用正则表达式获取系统状态栏高度的方法,以避免因API调用时机问题导致的页面闪烁。此外,还提及了5+API的isImmersedStatusbar()和getStatusbarHeight()方法作为辅助判断和获取状态栏高度的选项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

原文:https://www.cnblogs.com/fuzitu/p/12557152.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值