H5浏览器上使用100vh的坑及解决办法

背景:

近期开发一个移动端的详情页,布局是有一排操作按钮固定在页面底部,中间内容部分在页面内总想滚动,开发时我把页面中间部分的高度设置为100vh - 50px,overflow:auto;在浏览器的控制台模式看没问题,微信上的浏览器和小程序看这个页面也没问题,最后突然发现在安卓和苹果手机的浏览器上展示有问题,具体表现为:

  1. 安卓(华为mate60):页面展示地址栏和底部导航栏时,看不到操作按钮,当页面滚动时顶部地址栏隐藏,底部的操作按钮被滚动上来了
  2. 苹果:页面直接不展示底部的操作按钮,无论页面滚动导致顶部地址栏是否隐藏

经查阅资料,移动端浏览器包含顶部地址栏,搜索栏,底部导航栏,它们会占据一定的高度,影响网页内容的可视区域。通常情况下,100vh 即视口高度会减去这些浏览器 UI 的高度,以确保网页内容不会被这些 UI 遮挡。

但是移动端的地址栏有时可见,有时隐藏,从而改变了视口的可见大小。 这些浏览器没有将100vh高度调整为视口高度变化时屏幕的可见部分,而是将100vh设置为浏览器的高度,并隐藏了地址栏。 结果是,当地址栏可见时,屏幕的底部将被切除。 如下所示

当不展示地址栏时,浏览器的100vh为屏幕可视区的高度,当展示地址栏时,顶部地址栏占了高度,此时网站内容被往下移,因此网站底部的内容被切断不展示。 因此用100vh会造成很大影响,当用户首次访问移动设备上的网站时,地址栏将在顶部可见,导致底部的元素没有显示。

解决方案:使用window.innerHeight

页面加载时,将高度设置为window.innerHeight可以将高度正确设置为窗口的可见部分。 如果地址栏可见,则window.innerHeight将为全屏的高度。 如果地址栏是隐藏的,则window.innerHeight将是屏幕上可见部分的高度,至此完美解决~

注意⚠️

100vh在移动浏览器中以微妙但基本的方式被破坏,这使其几乎无用。 最好避免100vh ,而是依靠javascript设置高度以获得完整的视口体验。

因此,在设计响应式网页时,最好测试在不同的手机浏览器上,以确保页面的可视区域能够正确适应不同的环境。

  • 4
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Android中,WebView是用于显示网页内容的组件,而且它还具有加载HTML页面的功能。通常情况下,WebView会将网页内容在应用内部显示,但是我们也可以通过设置WebView的方式,使其在外部浏览器中打开网页。 要在外部浏览器中打开网页,我们可以通过重写WebView的WebViewClient类中的shouldOverrideUrlLoading方法来实现。该方法会在WebView加载URL之前被调用,并返回一个boolean值,该值表示是否由WebView处理URL。 代码示例如下: webView.setWebViewClient(new WebViewClient(){ @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { // 使用外部浏览器打开网页 Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse(url)); startActivity(intent); return true; // 返回true表示由外部浏览器处理URL } }); 在上述代码中,我们首先创建了一个WebViewClient对象,并重写了其中的shouldOverrideUrlLoading方法。在该方法中,我们创建了一个Intent对象,使用ACTION_VIEW action,将URL转换为Uri,并通过该Intent启动外部浏览器来打开网页。然后我们返回true,表示由外部浏览器处理URL。 最后,我们将创建的WebViewClient对象设置给WebView,这样在加载网页,WebView会先调用shouldOverrideUrlLoading方法来判断是否在外部浏览器中打开。若返回true,则会在外部浏览器中打开网页;若返回false,则会在WebView中显示网页内容。 通过上述方法,我们可以实现在Android中使用WebView加载H5页面使用外部浏览器打开网页。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值