不要用100vh做移动响应

SegmentFault

共 1079字,需浏览 3分钟

 ·

2022-06-10 05:11

作者:前端小智

简介:思否百万阅读,励志退休后,回家摆地摊的人。

来源:SegmentFault  思否社区 


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


.content {   height: 100vh;
}


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


  • 大部分移动端的Chrome和Firefox浏览器在顶部都有一个UI(地址栏等)。

  • 在Safari浏览器上,地址栏在底部,这就变得更加棘手了。

  • 不同的浏览器有不同大小的视口

  • 移动设备计算浏览器视口为(顶栏+文档+底栏)=100vh

  • 整个文档使用 100vh 填充到页面中


问题



谷歌



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


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


解决方案



通过JS检测应用程序的高度


const documentHeight = () => {
 const doc = document.documentElement
 doc.style.setProperty('--doc-height', `${window.innerHeight}px`)}
window.addEventListener(‘resize’, documentHeight)documentHeight()


使用 css 变量


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


最后结果




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




点击左下角阅读原文,到 SegmentFault 思否社区 和文章作者展开更多互动和交流,扫描下方”二维码“或在“公众号后台回复“ 入群 ”即可加入我们的技术交流群,收获更多的技术文章~

- END -


浏览 12
点赞
评论
收藏
分享

手机扫一扫分享

举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

举报