- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
以下CSS规则有什么作用:
.clear { clear: both; }
最佳答案
我不会在这里详细解释浮点数的工作原理,因为这个问题通常集中在为什么使用clear: both;
或clear: both;
的作用是什么...
我将使答案简单明了,并以图形方式向您说明为什么需要clear: both;
或它的作用...
通常,设计人员将元素向左或向右浮动,从而在另一侧创建一个空白空间,以允许其他元素占用剩余空间。
为什么它们会浮动元素?
当设计人员并排需要2个块级元素时,元素将浮动。例如说我们要设计一个基本的网站,其布局如下图所示。
演示图像的Live Example。
演示代码
/* CSS: */
* { /* Not related to floats / clear both, used it for demo purpose only */
box-sizing: border-box;
-moz-box-sizing: border-box;
-webkit-box-sizing: border-box;
}
header, footer {
border: 5px solid #000;
height: 100px;
}
aside {
float: left;
width: 30%;
border: 5px solid #000;
height: 300px;
}
section {
float: left;
width: 70%;
border: 5px solid #000;
height: 300px;
}
.clear {
clear: both;
}
<!-- HTML -->
<header>
Header
</header>
<aside>
Aside (Floated Left)
</aside>
<section>
Content (Floated Left, Can Be Floated To Right As Well)
</section>
<!-- Clearing Floating Elements-->
<div class="clear"></div>
<footer>
Footer
</footer>
header
,
footer
,
aside
,
section
(和其他HTML5元素)添加为
display: block;
,以明确提及这些元素是块级元素。
header
没有浮点数,接下来是我将用于网站侧边栏的
aside
标记,因此我将元素向左浮起。
div
保留了未使用其右侧的空间,这将允许
div
移入剩余空间。
div
's will render one after the other if they are NOT floated
div
will shift beside each other if floated left or right
clear: both;
以及为什么?
.clear
的类,它包含一个值为
clear
的名为
both
的属性。因此,让我们看看为什么需要
both
。
aside
和
section
元素浮动到左侧,所以假设有一个场景,我们有一个池,其中
header
是坚实的土地,
aside
和
section
漂浮在池中,而页脚是再次坚实的土地,像这样。
div
示例进行说明)
red
背景将按预期显示,因为容器不包含任何浮动对象。
clear: both;
之后,容器元素将被拉伸到其浮动元素尺寸。
clear: both;
的另一个原因是为了防止元素在剩余空间中向上移动。
div
Floated left resulting in section
moving into remaining space
div
cleared so that the section
tag will render below the floated div
s
footer
标签将在浮动元素之后呈现,因为在声明我的
clear
标签之前,我已经使用过
footer
类,这可以确保清除所有浮动元素(左/右)到这一点。
div
元素,而该元素不是
div
元素。因此,这里出现了clearfix。
.wrapper_having_floated_elements:after { /* Imaginary class name */
content: "";
clear: both;
display: table;
}
:after
使用的
class
伪元素。这将在包装器元素自身关闭之前为其创建一个虚拟元素。如果我们查看dom,您会看到它在Document树中的显示方式。
div
之后呈现,在该子元素中我们清除了浮点数,这不过是等于有一个具有
div
属性的空
clear: both;
元素,我们也将其用于此目的。现在为什么
display: table;
和
content
不在此答案范围内,但是您可以了解有关
pseudo element here的更多信息。
:after
pseudo使用。
clear: both;
,它将清除所有向左或向右浮动的元素。
------------------ ----------------------------------
div1(Floated Left) Other div takes up the space here
------------------ ----------------------------------
div1
下进行另一个div渲染,那么将使用
clear: both;
,这样可以确保清除所有浮动,无论是左侧还是右侧
------------------
div1(Floated Left)
------------------
<div style="clear: both;"><!--This <div> acts as a separator--></div>
----------------------------------
Other div renders here now
----------------------------------
关于css - CSS规则“清除:两者”有什么作用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32267927/
我有一个网站,我正在通过学校参加比赛,但我在清除 float 元素方面遇到了问题。 该网站托管在 http://www.serbinprinting.com/corey/development/
我有一个清除按钮,需要使用 JQuery 函数清除该按钮单击时的 TextBox 值(输入的)。 最佳答案 您只需将单击事件附加到按钮即可将输入元素的值设置为空。 $("#clearButton").
我们已经创建了一个保存到 CoreData 然后同步到 CloudKit 的 iOS 应用程序。在测试中,我们还没有找到一种方法来清除应用程序 iCloud 容器中的数据(用于用户私有(private
这是一个普遍的问题,也是我突然想到并且似乎有道理的问题。我看到很多人使用清除div 并且知道这有时不受欢迎,因为它是额外的标记。我最近开始使用 因为它接缝代表了它的实际用途。 当然都引用了:.clea
我有两个单选按钮。如果我检查第一个单选按钮下面的数据将填充在组合框中。之后我将检查另一个单选按钮,我想清除组合框值。 EmployeeTypes _ET = new EmployeeTypes(
我一直在玩 Canvas ,我正在尝试制作一个可以移动和跳跃的正方形,移动部分已经完成,但是跳跃部分有一个问题:每次跳跃时它都会跳得更快 here's a jsfiddle 这是代码: ///////
我该如何在 Dart 上做到这一点? 抓取tbody元素后,我想在其上调用empty(),但这似乎不存在: var el = query('#search_results_tbody'); el.em
我需要创建一个二维模拟,但是在设置新的“框架”时,旧的“框架”不会被清除。 我希望一些圆圈在竞技场中移动,并且每个循环都应删除旧圆圈并生成新圆圈。一切正常,但旧的没有被清除并且仍然可见,这就是我需要改
无论我使用set statusline将状态行更改为什么,我的状态行都不会改变。看起来像 ".vimrc" 39L, 578C
在 WPF 应用程序中,我有一个 ListView 绑定(bind)到我的 ViewModel 上的一个 ObservableCollection。 在应用程序运行期间,我需要删除并重新加载集合中的所
我有一个大型程序,一个带有图形的文本扭曲游戏。在我的代码中的某处,我使用 kbhit() 我执行此代码来清除我的输入缓冲区: while ((c = getchar()) != '\n' && c !
我正在将所有网站的页面加载到主索引页面中,并通过将 href 分成段并在主域名后使用 .hash 函数添加段来更新 URL 显示,如下所示: $('a').click(function(event)
我有一个带有 的表单和 2 控件来保存和重置表单。我正在触发 使用 javascript __doPostBack()函数并在其中传递一个值 __EVENTARGUMENT如果面板应该重置。 我的代
我目前有一堆 UIViewController,每个都是在前一个之上呈现的模式 ViewController。我的问题是我不需要一堆 UIViewController,我只需要最后一个。因此,当出现新
我在一个类中有一些属性方法,我想在某个时候清除这个属性的缓存。 示例: class Test(): def __init__(self): pass @property
在此Test Link我试图将标题和主站点导航安装到博客脚本的顶部。 我清除:两者;在主要网站脚本上工作,但现在把所有东西都扔到了一边。尝试了无数次 fixex 都没有成功!提前感谢 Ant 指点解决
我似乎无法正确清除布局。看this 我无法阻止左栏中的元素向下推右栏中的元素。谁能帮忙? Screenshot with some pointy arrows (死链接) 最佳答案 问题标记/样式似
我希望能够在某个类 (sprite-empos) 之后清除 '' 中的内容,想知道是否有不添加任何新类或不使用 js 的方法(我在下面尝试过不工作)? 为了明确它是“985”,我想在某个视口(view
我想清除ptr_array boost::ptr_array a; ... a.clear(); // missing 如何清理 ptr 容器? 最佳答案 它应该表现得像一个数组,您不能在 C++
这是我使用多 map 制作的一个简单的事件系统;当我使用 CEvents::Add(..) 方法时,它应该插入并进入多重映射。问题是,当我触发这些事件时, multimap 似乎是空的。我确定我没有调
我是一名优秀的程序员,十分优秀!