javascript - 关于使用overflow: hidden来清除浮动的疑问
问题描述
正常情况下,给浮动的父元素设置overflow:hidden;就可以清楚浮动,但是我发现被浮动元素的父元素是body时,给body设置overflow:hidden,是无法清除浮动的,有人说是body不属于普通流,所以无效,有谁能解释下吗?
感谢:CRIMX借用王大陆的一句话:
你这种人不是大神,就是走在成为大神的路上。
问题解答
回答1:这是因为并没有产生新的 BFC
产生新 BFC 的一个条件:
Block-level, non-replaced elements in normal flow when ’overflow’ does not compute to ’visible’ (except if the ’overflow’ property’s value has been propagated to the viewport).
为什么对 <body> 设置 overflow 会扩散到 viewport:
UAs must apply the ’overflow’ property set on the root element to the viewport. When the root element is an HTML 'HTML' element or an XHTML 'html' element, and that element has an HTML 'BODY' element or an XHTML 'body' element as a child, user agents must instead apply the ’overflow’ property from the first such child element to the viewport, if the value on the root element is ’visible’. The ’visible’ value when used for the viewport must be interpreted as ’auto’. The element from which the value is propagated must have a used value for ’overflow’ of ’visible’.
相关文章:
1. 我在centos容器里安装docker,也就是在容器里安装容器,报错了?2. golang - 用IDE看docker源码时的小问题3. css - 定位为absolute的父元素中的子元素 如何设置在父元素的下面?4. JavaScript事件5. debian - docker依赖的aufs-tools源码哪里可以找到啊?6. 关docker hub上有些镜像的tag被标记““This image has vulnerabilities””7. javascript - 原生canvas中如何获取到触摸事件的canvas内坐标?8. android - 用textview显示html时如何写imagegetter获取网络图片9. css3 - css怎么实现图片环绕的效果10. docker gitlab 如何git clone?
