今天小编给大家分享一下不应该依赖CSS 100vh的原因是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。如果有一个文本和一个按钮,我们想让文本粘在上面,而按钮粘在下面!使用CSS Flex 似乎很容易做到。Loremipsumdolorsitamet…在真机检查一下效果:酷! Git add, git commit, git push, oh yeah!当然,是有的! 要看到这个问题,你需要在真实的手机或模拟器上查看你的应用程序。在本文中使用的 iPhone 13(iOS 15.2)进行测试,下面是结果:啥,底部按钮跑哪里去了?顺便说一下,它在安卓手机上甚至不能按预期工作。我对这个问题进行了一番调查,发现了其中的原因。简短的答案是,浏览器的工具栏高度没有被考虑在内。如果你想深入了解为什么会发生这种情况,Stack Overflow的这个帖子免费云主机、域名很有帮助。第一个建议是尽量少用 vh
。例如,在上面的代码中,你可以使用一个 sticky 按钮,避免使用vh
单位。Loremipsumdolorsitamet…效果:它在横向模式下也很好:说实话,结果是好的,但你不能总是用 sticky
元素来解决 100vh
的问题。时,使用 vh
的目的是为了简单地创建与视口高度相等的部分。例如,当你在建立登陆页面时,这很常见。在这些情况下,position sticky
不会有帮助,这里介绍一下 fill-available
属性。它用起来很简单,只要记住使用前缀和回退值就可以了。效果:
而且,当你旋转设备时,它还会更新高度,太棒了!用 fill-available
修复 100vh 的问题确实很直接,但在调查这个解决方案时,也遇到过一些问题。页面上有 声明,会使
甚至不能在安卓浏览器上工作:因此,为了解决这个问题,必须从页面中删除 fill-available
在 Chrome 浏览器上无法正常工作。doctype
声明。在 min-height
(或 height
)为 fill-available
的元素上添加垂直 padding
(bottom 和 top),Safari浏览器上会导致问题,高度不会正确。要解决这个问题,只需将你的内容包在另一个 div
元素内,就可以了:需要注意的一件事是,不能在 fill-available
属性下使用 calc()
。所以,下面的CSS规则就不会生效:例如,如果需要在元素上有一半的可用高度,必须使用JavaScript。使用JavaScript修复移动设备上的100vh问题可以使用 window 的 innerHeight
属性,将元素 height
(或minHeight
)设置为window.innerHeight
,如下所示:效果:接着,再介绍一种花销的方式。 一些开发者喜欢根据窗口的内部高度定义一个CSS变量,并使用该变量来设计他们所需的元素。代码如下:在 CSS 中:最后一件事是当窗口被调整大小或设备方向改变时,重新计算这个值:以上就是“不应该依赖CSS 100vh的原因是什么”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注云技术行业资讯频道。
本篇内容主要讲解“jquery选择器怎么表示”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷免费云主机、域名,实用性强。下面就让小编来带大家学习“jquery选择器怎么表示”吧! jquery选择器以美元符号($())开头;“$”符号是选取的意思,用于获…