你不应该依赖CSS 100vh,这就是原因!

网站建设3年前发布
30 0 0

如果有一个文本和一个按钮,我们想让文本粘在上面,而按钮粘在下面!使用CSS Flex 似乎很容易做到。,在真机检查一下效果:,20230306101454211357b582bdfb83d6c219b9b37f640a06148e774,酷! Git add, git commit, git push, oh yeah!,当然,是有的! 要看到这个问题,你需要在真实的手机或模拟器上查看你的应用程序。在本文中使用的 iPhone 13(iOS 15.2)进行测试,下面是结果:,2023030610145577c84e21306a534b28241689b24bad616b950f555,啥,底部按钮跑哪里去了?,顺便说一下,它在安卓手机上甚至不能按预期工作。,202303061014557406e6978900f25b9875194921b79ab0355d7f847,我对这个问题进行了一番调查,发现了其中的原因。简短的答案是,浏览器的工具栏高度没有被考虑在内。如果你想深入了解为什么会发生这种情况,Stack Overflow的这个帖子很有帮助。,第一个建议是尽量少用 vh​。例如,在上面的代码中,你可以使用一个 sticky 按钮,避免使用vh单位。,效果:,202303061016006161abe59841e1e9c02069a1ca411f94b56d8b922,它在横向模式下也很好:,20230306101456053d3cc22fe6818105e9550db43d4760b96380390,说实话,结果是好的,但你不能总是用 sticky​  元素来解决 100vh 的问题。,时,使用 vh​ 的目的是为了简单地创建与视口高度相等的部分。例如,当你在建立登陆页面时,这很常见。在这些情况下,position sticky​不会有帮助,这里介绍一下 fill-available属性。它用起来很简单,只要记住使用前缀和回退值就可以了。,效果:,202303061014576633bd948d844887b5f6659d3f37de5ab858ad683,而且,当你旋转设备时,它还会更新高度,太棒了!,2023030610145731d2afc3889d04fcbf085823a1354d1df35b6e575,用 fill-available 修复 100vh 的问题确实很直接,但在调查这个解决方案时,也遇到过一些问题。,页面上有  <!DOCTYPE html>​ 声明,会使 fill-available 在 Chrome 浏览器上无法正常工作。,202303061014581951cd263bd509bd3b5975d668c121c64b16a7408,甚至不能在安卓浏览器上工作:,20230306101458227f910425cf362776a4907b7fdb32ab068a5d870,因此,为了解决这个问题,必须从页面中删除 doctype 声明。,在 min-height​(或 height​)为 fill-available​的元素上添加垂直 padding (bottom 和  top),Safari浏览器上会导致问题,高度不会正确。,202303061016009262cca67e05c4a61911155f6fa1d475a3c15c968,要解决这个问题,只需将你的内容包在另一个 div 元素内,就可以了:,3. fill-available 不能与 calc() 一起使用,需要注意的一件事是,不能在 fill-available​ 属性下使用 calc()。所以,下面的CSS规则就不会生效:,例如,如果需要在元素上有一半的可用高度,必须使用JavaScript。,使用JavaScript修复移动设备上的100vh问题,可以使用 window 的 innerHeight​ 属性,将元素 height​ (或minHeight​)设置为window.innerHeight,如下所示:,效果:,20230306101459e366e12216c99f65e9d51331ff35b58c33404f933,接着,再介绍一种花销的方式。一些开发者喜欢根据窗口的内部高度定义一个CSS变量,并使用该变量来设计他们所需的元素。代码如下:,在 CSS 中:,最后一件事是当窗口被调整大小或设备方向改变时,重新计算这个值:,在我看来,你应该先用CSS的解决方案。,作者:Mehdi Namvar  ,译者:前端小智,来源:mediun,原文:https://ilxanlar.mdium.com/you-shouldnt-relyon-css-100vh-and-here-s-why-1b4721e74487​

© 版权声明

相关文章