浮动小识

简单说浮动即:css样式中的定位属性。元素的水平方向浮动,意味着元素只能左右移动而不能上下移动,一个浮动元素会尽量向左或向右移动,直到它的外边缘碰到包含框或另一个浮动框的边框为止。由于浮动框不在文档的普通流中,所以文档的普通流中的块框表现得就像浮动框不存在一样。其周围的元素也会重新排列
(1、浮动元素之后的元素将围绕它。 2、浮动元素之前的元素将不会受到影响。3、如果图像是右浮动,下面的文本流将环绕在它左边:)。
如果你把几个浮动的元素放到一起,如果有空间的话,它们将彼此相邻,实现元素的一行排列。。(注意,浮动的元素会脱离原本的文档流)

讲解:
先设置三个框!

.box1{
				background-color: red;
				width: 200px;
				height: 200px;
				padding: 1px;
			}
.box2{
				background-color: blue;
			width: 200px;
				height: 200px;
				padding: 1px;
			}
.box3{
				background-color: green;
			width: 200px;
				height: 200px;
				padding: 1px;
			}

在这里插入图片描述
如图所示:将框 1 向右浮动时,框1脱离文档流并且向右移动,直到它的右边缘碰到包含框的右边缘:

.box1{
				background-color: red;
				width: 200px;
				height: 200px;
				padding: 1px;
				float: right;
			}
.box2{
				background-color: blue;
			width: 200px;
				height: 200px;
				padding: 1px;
				
			}
.box3{
				background-color: green;
			width: 200px;
				height: 200px;
				padding: 1px;
				
				}

在这里插入图片描述
但如果框 1 向左浮动。会消失,因为被框2覆盖住了,从视图中消失。
因为它脱离文档流,不再处于文档流中,所以它不占据空间。

.box1{
				background-color: red;
				width: 200px;
				height: 200px;
				padding: 1px;
				float: left;
			}
.box2{
				background-color: blue;
			width: 200px;
				height: 200px;
				padding: 1px;
				
			}
.box3{
				background-color: green;
			width: 200px;
				height: 200px;
				padding: 1px;
				
				}

在这里插入图片描述
如果把所有三个框都向左移动,那么框 1 向左浮动直到碰到包含框,另外两个框向左浮动直到碰到前一个浮动框。

	.box1{
				background-color: red;
				width: 200px;
				height: 200px;
				padding: 1px;
				float: left;
			}
.box2{
				background-color: blue;
			width: 200px;
				height: 200px;
				padding: 1px;
				float: left;
				
			}
.box3{
				background-color: green;
			width: 200px;
				height: 200px;
				padding: 1px;
				float: left;
				}

在这里插入图片描述
总之,浮动后脱离原先文档流,后面元素会顶替被浮动元素的位置。如上列子:第一框浮动后,框1脱离原先的文档流,故框2会占据框1的位置,框3和框2仍处于原先的文档流中,故会框2框3仍按照原先排布方式排列。若框2框1均浮动,则只能在页面视图看到框3,框2框1被框三遮盖

说了浮动,为了消除浮动对其他页面元素的影响。消除浮动有一下几种方法:
1、在被浮动的元素的下一元素的CSS样式中加上 clear:both.

.box1{
				background-color: red;
				width: 200px;
				height: 200px;
				padding: 1px;
				float: left;
			}
.box2{
				background-color: blue;
			width: 200px;
				height: 200px;
				padding: 1px;
				clear: both;
				
			}
.box3{
				background-color: green;
			width: 200px;
				height: 200px;
				padding: 1px;

				}

在这里插入图片描述
2、给被浮动的元素设置边框,强行占据位置,让后面的元素不会因为前者浮动而受影响。
在这里插入图片描述

3、给下一元素设置值为hidden或者auto (overflow: auto;)。也可以清楚上一元素浮动产生的影响。
在这里插入图片描述
在这里插入图片描述

已经博主授权,源码转载自 https://pan.quark.cn/s/a4b39357ea24 QueueForMcu 基于单片机实现的队列功能模块,主要用于8位、16位、32位非运行RTOS的单片机应用,兼容大多数单片机平台。 开源代码:https://.com/xiaoxinpro/QueueForMcu 一、特性 动态创建队列对象 动态设置队列数据缓冲区 静态指定队列元素数据长度 采用值传递的方式保存队列数据 二、快速使用 三、配置说明 目前QueueForMcu只有一个静态配置项,具体如下: 在文件 中有一个宏定义 用于指定队列元素的数据长度,默认是 ,可以根据需要更改为其他数据类型。 四、数据结构 队列的数据结构为 用于保存队列的状态,源码如下: 其中 为配置项中自定义的数据类型。 五、创建队列 1、创建队列缓存 由于我们采用值传递的方式保存队列数据,因此我们在创建队列前要手动创建一个队列缓存区,用于存放队列数据。 以上代码即创建一个大小为 的队列缓存区。 2、创建队列结构 接下来使用 创建队列结构,用于保存队列的状态: 3、初始化队列 准备好队列缓存和队列结构后调用 函数来创建队列,该函数原型如下: 参数说明: 参考代码: 六、压入队列 1、单数据压入 将数据压入队列尾部使用 函数,该函数原型如下: 参数说明: 返回值说明: 该函数会返回一个 枚举数据类型,返回值会根据队列状态返回以下几个值: 参考代码: 2、多数据压入 若需要将多个数据(数组)压入队列可以使用 函数,原理上循环调用 函数来实现的,函数原型如下: 参数说明: 当数组长度大于队列剩余长度时,数组多余的数据将被忽略。 返回值说明: 该函数将返回实际被压入到队列中的数据长度。 当队列中的剩余长度富余...
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值