CSS Float(浮动)

   CSS 的 Float(浮动),会使元素向左或向右移动,其周围的元素也会重新排列。

   Float(浮动),往往是用于图像,但它在布局时一样非常有用。

 

元素浮动

   元素的水平方向浮动,意味着元素只能左右移动而不能上下移动。

   一个浮动元素会尽量向左或向右移动,直到它的外边缘碰到包含框或另一个浮动框的边框为止。

   浮动元素之后的元素将围绕它。

   浮动元素之前的元素将不会受到影响。

   如果图像是右浮动,下面的文本流将环绕在它左边:

<!DOCTYPE html>
<html>  
<head>  
    <meta charset="utf-8">  
    <title>自学教程(如约智惠.com)</title>  
	<style>
		img 
		{
			float:right;
		}
	</style>
</head>  
<body > 
	<p>在下面的段落中,我们添加了一个 <b>float:right</b> 的图片。导致图片将会浮动在段落的右边。</p>
	<p>
		<img src="logocss.gif" width="95" height="84" />
		这是一些文本。这是一些文本。这是一些文本。
		这是一些文本。这是一些文本。这是一些文本。
		这是一些文本。这是一些文本。这是一些文本。
		这是一些文本。这是一些文本。这是一些文本。
		这是一些文本。这是一些文本。这是一些文本。
		这是一些文本。这是一些文本。这是一些文本。
		这是一些文本。这是一些文本。这是一些文本。
		这是一些文本。这是一些文本。这是一些文本。
		这是一些文本。这是一些文本。这是一些文本。
		这是一些文本。这是一些文本。这是一些文本。
	</p>

	
</body>
</body>  
</html>

彼此相邻的浮动元素

 

   如果你把几个浮动的元素放到一起,如果有空间的话,它们将彼此相邻。

 

   在这里,我们对图片廊使用 float 属性:

<!DOCTYPE html>
<html>  
<head>  
    <meta charset="utf-8">  
    <title>自学教程(如约智惠.com)</title>  
	<style>
		.thumbnail 
		{
			float:left;
			width:100px;
			height:90px;
			margin:5px;
		}
	</style>
</head>  
<body >
	<h3>图片库</h3>
	<p>试着调整窗口,看看当图片没有足够的空间会发生什么。</p>
	<img class="thumbnail" src="klematis_small.jpg" width="107" height="90">
	<img class="thumbnail" src="klematis2_small.jpg" width="107" height="90">
	<img class="thumbnail" src="klematis3_small.jpg" width="107" height="90">
	<img class="thumbnail" src="klematis4_small.jpg" width="107" height="90">
	<img class="thumbnail" src="klematis_small.jpg" width="107" height="90">
	<img class="thumbnail" src="klematis2_small.jpg" width="107" height="90">
	<img class="thumbnail" src="klematis3_small.jpg" width="107" height="90">
	<img class="thumbnail" src="klematis4_small.jpg" width="107" height="90">
</body>
</body>  
</html>

清除浮动--使用clear

   元素浮动之后,周围的元素会重新排列,为了避免这种情况,使用clear属性。

   clear属性指定元素两侧不能出现浮动元素。

   使用clear属性往文本中添加图片廊:

<!DOCTYPE html>
<html>  
<head>  
    <meta charset="utf-8">  
    <title>自学教程(如约智惠.com)</title>  
	<style>
		.thumbnail 
		{
			float:left;
			width:100px;
			height:90px;
			margin:5px;
		}
		
		.text_line
		{
			clear:both;
			margin-bottom:2px;
		}
	</style>
</head>  
<body >
	<h3>图片库</h3>
	<p>试着调整窗口,看看当图片没有足够的空间会发生什么。</p>
	<img class="thumbnail" src="klematis_small.jpg" width="107" height="90">
	<img class="thumbnail" src="klematis2_small.jpg" width="107" height="80">
	<img class="thumbnail" src="klematis3_small.jpg" width="116" height="90">
	<img class="thumbnail" src="klematis4_small.jpg" width="120" height="90">
	<h3 class="text_line">第二行</h3>
	<img class="thumbnail" src="klematis_small.jpg" width="107" height="90">
	<img class="thumbnail" src="klematis2_small.jpg" width="107" height="80">
	<img class="thumbnail" src="klematis3_small.jpg" width="116" height="90">
	<img class="thumbnail" src="klematis4_small.jpg" width="120" height="90">
</body>
</body>  
</html>

 

实例

 

  为图像添加边框和边距并浮动到段落的右侧

<!DOCTYPE html>
<html>  
<head>  
    <meta charset="utf-8">  
    <title>自学教程(如约智惠.com)</title>  
	<style>
img 
{
	float:right;
	border:1px dotted black;
	margin:0px 0px 15px 20px;
}
</style>
</head>

<body>
<p>
	在下面的段落中,图像将向右浮动。黑色虚线边界添加到图像。
我们还添加了边缘的0 px的顶部和右侧 margin,15 px底部margin,和20 px左侧的margin的图像。使得文本远离图片:</p>
<p>
<img src="logocss.gif" width="95" height="84" />
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
</p>
</body>

</html>

  标题和图片向右侧浮动

<!DOCTYPE html>
<html>  
<head>  
    <meta charset="utf-8">  
    <title>自学教程(如约智惠.com)</title>  
	<style>
	div
{
	float:right;
	width:120px;
	margin:0 0 15px 20px;
	padding:15px;
	border:1px solid black;
	text-align:center;
}
</style>
</head>

<body>
<div>
<img src="logocss.gif" width="95" height="84" /><br>
CSS is fun!
</div>
<p>
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
</p>

<p>
	在上面的段落中,div元素是120像素宽,它包含了图像。
	div元素会向右浮动。
	Margins 被添加到div使得文本远离div。
	Borders和padding被添加到div框架的图片和标题中
</p>
</body>
</html>

   让段落的第一个字母浮动到左侧

<!DOCTYPE html>
<html>  
<head>  
    <meta charset="utf-8">  
    <title>自学教程(如约智惠.com)</title>  
	<style>
		span
		{
			float:left;
			width:1.2em;
			font-size:400%;
			font-family:algerian,courier;
			line-height:80%;
		}
	</style>
</head>

<body>
	<p>
		<span>这</span>是一些文本。
		这是一些文本。这是一些文本。
		这是一些文本。这是一些文本。这是一些文本。
		这是一些文本。这是一些文本。这是一些文本。
		这是一些文本。这是一些文本。这是一些文本。
		这是一些文本。这是一些文本。这是一些文本。
		这是一些文本。这是一些文本。这是一些文本。
		这是一些文本。这是一些文本。这是一些文本。
	</p>

	<p>
		<span>在</span>上面的段落中, 第一个字嵌入在span 元素中。
		这个 span 元素的宽度是当前字体大小的1.2倍。
		这个 span 元素是当前字体的400%(相当大), line-height 为80%。
		文字的字体为"Algerian"。
	</p>

</body>
</html>

  创建一个没有表格的网页

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"> 
<title>自学教程(如约智惠.com)</title> 
<style>
* {
    box-sizing: border-box;
}
body {
    margin: 0;
}
.header {
    background-color: #2196F3;
    color: white;
    text-align: center;
    padding: 15px;
}
.footer {
    background-color: #444;
    color: white;
    padding: 15px;
}
.topmenu {
    list-style-type: none;
    margin: 0;
    padding: 0;
    overflow: hidden;
    background-color: #777;
}
.topmenu li {
    float: left;
}
.topmenu li a {
    display: inline-block;
    color: white;
    text-align: center;
    padding: 16px;
    text-decoration: none;
}
.topmenu li a:hover {
    background-color: #222;
}
.topmenu li a.active {
    color: white;
    background-color: #4CAF50;
}
.column {
    float: left;
    padding: 15px;
}
.clearfix::after {
    content: "";
    clear: both;
    display: table;
}
.sidemenu {
    width: 25%;
}
.content {
    width: 75%;
}
.sidemenu ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
}
.sidemenu li a {
    margin-bottom: 4px;
    display: block;
    padding: 8px;
    background-color: #eee;
    text-decoration: none;
    color: #666;
}
.sidemenu li a:hover {
    background-color: #555;
    color: white;
}
.sidemenu li a.active {
    background-color: #008CBA;
    color: white;
}
</style>
</head>
<body>

<ul class="topmenu">
  <li><a href="#home" class="active">主页</a></li>
  <li><a href="#news">新闻</a></li>
  <li><a href="#contact">联系我们</a></li>
  <li><a href="#about">关于我们</a></li>
</ul>

<div class="clearfix">
  <div class="column sidemenu">
    <ul>
      <li><a href="#flight">The Flight</a></li>
      <li><a href="#city" class="active">The City</a></li>
      <li><a href="#island">The Island</a></li>
      <li><a href="#food">The Food</a></li>
      <li><a href="#people">The People</a></li>
      <li><a href="#history">The History</a></li>
      <li><a href="#oceans">The Oceans</a></li>
    </ul>
  </div>

  <div class="column content">
    <div class="header">
      <h1>The City</h1>
    </div>
    <h1>Chania</h1>
    <p>Chania is the capital of the Chania region on the island of Crete. The city can be divided in two parts, the old town and the modern city.</p>
    <p>You will learn more about responsive web pages in a later chapter.</p>
  </div>
</div>

<div class="footer">
  <p>底部文本</p>
</div>

</body>
</html>

 

 

 

CSS 中所有的浮动属性

"CSS" 列中的数字表示不同的 CSS 版本(CSS1 或 CSS2)定义了该属性。

属性描述CSS
clear指定不允许元素周围有浮动元素。left
right
both
none
inherit
1
float指定一个盒子(元素)是否可以浮动。left
right
none
inherit
1

 

参考:

https://www.yuque.com/docs/share/d125f507-bc07-4f02-87da-f912dbafd63f

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值