不要用100vh做移动响应,有问题?

移动开发
一般来说,我们使用 height:100vh 进行全屏布局,这是一种很方便的响应式方法。但当在实际设备上测试我们的设计时,我们遇到了几个问题。

一般来说,我们使用 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也没有问题,这样的用户体验得到很大的提升。

责任编辑:赵宁宁 来源: 大迁世界
相关推荐

2022-08-24 10:03:18

CSS文本按钮

2021-01-20 07:28:02

nullcollections对象

2016-10-21 10:00:01

HTML标签WEB

2018-11-29 11:18:11

VLANVPC数据中心

2023-04-27 13:25:22

索引合并MySQL

2022-04-13 08:43:46

工厂模式接口解析器

2023-02-26 15:49:08

元宇宙ChatGPT

2018-03-12 10:57:14

JavaKotlin语法

2015-01-26 17:25:08

应急响应预案企业安全风险

2015-08-04 08:56:14

swift子类

2022-02-22 09:25:11

PandasETL数据分析

2015-03-19 14:53:17

面向对象程序员新手程序员

2013-08-16 11:26:24

程序员面向对象

2015-01-09 15:22:11

2019-10-12 09:30:48

微信外挂

2018-03-15 09:23:24

编程语言程序员Java

2012-09-19 09:45:16

移动互联网广告模式

2018-07-12 09:04:15

RAID阵列硬盘

2014-03-31 16:15:47

移动应用优化

2021-11-01 07:00:32

IP字符串数据
点赞
收藏

51CTO技术栈公众号