前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >不要用100vh做移动响应

不要用100vh做移动响应

作者头像
前端小智@大迁世界
发布2022-06-02 10:14:09
8260
发布2022-06-02 10:14:09
举报
文章被收录于专栏:终身学习者

本文 GitHub https://github.com/qq449245884/xiaozhi 已收录,有一线大厂面试完整考点、资料以及我的系列文章。

一般来说,我们使用 height:100vh 进行全屏布局,这是一种很方便的响应式方法。

代码语言:javascript
复制
.content {
   height: 100vh;
}

但当在实际设备上测试我们的设计时,我们遇到了几个问题。

  • 大部分移动端的Chrome和Firefox浏览器在顶部都有一个UI(地址栏等)。
  • 在Safari浏览器上,地址栏在底部,这就变得更加棘手了。
  • 不同的浏览器有不同大小的视口
  • 移动设备计算浏览器视口为(顶栏+文档+底栏)=100vh
  • 整个文档使用 100vh 填充到页面中

问题

谷歌

已检测到滚动条问题。糟糕的用户滚动和难以浏览的内容。

注意:在Safari上测试了这个问题,它更加糟糕。

解决方案

通过JS检测应用程序的高度
代码语言:javascript
复制
const documentHeight = () => {
 const doc = document.documentElement
 doc.style.setProperty('--doc-height', `${window.innerHeight}px`)
}
window.addEventListener(‘resize’, documentHeight)
documentHeight()

使用 css 变量

代码语言:javascript
复制
:root {
 --doc-height: 100%;
}

html,
body {
 padding: 0;
 margin: 0;
 height: 100vh; /* fallback for Js load */
 height: var(--doc-height);
}

最后结果

现在没有任何额外的垂直滚动条出现,Safari也没有问题,这样的用户体验得到很大的提升。

代码部署后可能存在的BUG没法实时知道,事后为了解决这些BUG,花了大量的时间进行log 调试,这边顺便给大家推荐一个好用的BUG监控工具 Fundebug

作者:nirazanbasnet 译者:前端小智 来源:dev

原文:https://dev.to/nirazanbasnet/...

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-06-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 问题
    • 谷歌
    • 解决方案
      • 通过JS检测应用程序的高度
      • 使用 css 变量
      • 最后结果
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档