365bet官网是多少

深入理解和应用Float属性

发布时间 2025-08-30 11:27:24 作者 admin 阅读 1166

一、Float的特性1. 应用于文字围绕图片

2. 创建一个块级框

3. 多列浮动布局

4. 浮动元素的宽度、高度自适应,但可以设置其值。

二、核心解决的问题文字围绕图片:img标签与多个文本标签放置在一个容器中,如果img浮动,文本标签会围绕图片。

代码语言:javascript代码运行次数:0运行复制

001文件内容文件内容文内容文件内容

文件内容文件内容文件内容文件内容文件内内容文件内容

文件内容文件内容文件内容文件内容文件内容

文件内容文件内容文件内容文件内容文内容文件内容文件内容

p标签文件内容文件内容文件内容文件内容文件内容文容文件内容文件内容文件内容

Div标签文件内容文件内容文件内容文件内容文件内容文件内容

文件内容文件内容文件内容文件件内容文件内容文件内容

文件内容文件内容文件内容文件内容文件内容文件内容文件内容文件内容

文件内容文件内容文件内容文件内容文件内容文件内内容文件内容

文件内容文件内容文件内容文件容文件内容文件内容

文件内容文件内容文件内容文件容文件内容文件内容

2.1 这是一个问题浮动元素与正常元素相邻,且浮动元素与正常元素之间没有清除浮动,此时正常元素会被浮动元素盖住,但包含的内容会围绕浮动元素显示。

代码语言:javascript代码运行次数:0运行复制

001

002

001浮动,002没有浮动,但002元素本身被001盖住,但内容却围绕001显示。

三、非核心且主要应用领域分栏布局:让区块先水平排列,然后超出部分另起一行。

主要特点1.父级高度塌陷(这也是一个严重的问题)

代码语言:javascript代码运行次数:0运行复制.wrap{

background:red;

padding:10px;

width:auto;

}

.left{

background:gray;

width:200px;

height:100px;

float:left;

}

.right{

background:yellow;

width:100px;

height:100px;

float:left;

}代码语言:javascript代码运行次数:0运行复制

left

right

2.宽、高变成自适应子元素,但宽、高的设置有效

代码语言:javascript代码运行次数:0运行复制.wrap{

background:red;

padding:10px;

float:left;

}

.left{

width:100px;

background:gray;

}

.right:{

width:200px;

background:yellow;

}代码语言:javascript代码运行次数:0运行复制

left

right

2. 解决高度塌陷的问题首先我们需要了解BFC和IFC这两人个基本的概念,因为他与浏览器的渲染有着密切的关系。

1.BFC(块级格式化上下文)

他是一个独立渲染的区域,规定区域内部如何布局,且与外部毫不相干,主要规则如下:

1.1 内部的box会垂直方向,一个接一个地放置

1.2 Box垂直方向的距离由margin决定,属于同一个BFC的两个相邻box的Margin会发生重叠

1.3 BFC区域不会与float重叠

代码语言:javascript代码运行次数:0运行复制.head{

background:pink;

margin: 20px 0px;

height:100px;

}

.wrap{

background:red;

padding:10px;

margin:20px 0px;

overflow:hidden;

}

.left{

width:100px;

background:gray;

margin:10px 0px;

}

.right:{

width:200px;

background:yellow;

margin:20px 0px;

}代码语言:javascript代码运行次数:0运行复制

head

left

right

.head与.wrap两个box之间上下各设置有20px的外边距,但发生了重叠;

.head与.left两个之间,.head有20px的外边距,.left有10px的外边距,没有发生重叠,因为.wrap使其创建了BFC(overflow:hidden)。

1.4 每个box的margin 左边,与包含border box的左边相接触(右边一样),浮动也是如此

2. IFC(行级格式化上下文)

框从包含块的顶部开始,一个接一个水平放置。水平方向上的外边距、边框、内边距所占空间都放在一起(display为inline、inline-block;元素本身具有inline特性的元素都具体以下特征)。规则如下:

2.1 不能指定宽高

2.2 Margin、Padding、border垂直方向的无效

2.3 行框的左边紧贴包含块的左边,而行框的右边紧贴其包含框的右边,而浮动块可以插入在包含块边缘与行框之间。

2.4 行内框高度由line-height决定。

此节例子可以参考display章节的inline元素。

3. 解决方案主要根据BFC的原理实现,因为BFC的渲染的是整块区域,也就会计算出宽、高。这也是传说中的清除浮动的方案

3.1 父容器创建BFC方法

3.1.1 创建BFC的方法

a) Float除了none以外的取值;

b) Overflow除了visible以外的值;

c) Display值为table-cell、table-caption、inline-block、flex、inline-flex等

d) Position值为absloute、fixed

e) Fieldset元素

3.1.2 清除浮动

a) Float、overflow、display三种方式都可以清除浮动,但position、fieldset虽然创建了bfc但不可以清除浮动(也就是不能解决高度塌陷的问题)。主要原因为:position、fieldset都需要子元素来撑开父容器的高度,但子元素浮动后又不存在高度,所以失效。

b) Float、overflow、display示例代码:

代码语言:javascript代码运行次数:0运行复制.wrap{

background: gray;

padding: 10px;

overflow: auto;

}

.left, .right{

background: red;

float: left;

width: 200px;

height: 100px;

}

.right{

background: yellow;

}

.footer{

background: pink;

}代码语言:javascript代码运行次数:0运行复制

left

right

3.1.3 最后一个子元素clear:both

利用clear:both触发父容器重新计算高度的原理实现,示例代码如下:

代码语言:javascript代码运行次数:0运行复制.wrap{

background: gray;

padding: 10px;

}

.left, .right{

background: red;

float: left;

width: 200px;

height: 100px;

}

.right{

background: yellow;

}

.footer{

background: pink;

}

.clear{

clear: both;

zoom: 1;

}代码语言:javascript代码运行次数:0运行复制

left

right

3.1.4 After添加最后一个子元素

利用css的:after伪元素实现,动态插入元素并清除浮动:

代码语言:javascript代码运行次数:0运行复制.wrap{

background: gray;

padding: 10px;

}

.wrap:after{

content: '';

display: block;

overflow: hidden;

clear: both;

}

.left, .right{

background: red;

float: left;

width: 200px;

height: 100px;

}

.right{

background: yellow;

}

.footer{

background: pink;

}代码语言:javascript代码运行次数:0运行复制

left

right

4. 总结

1. 利用bfc方式清除浮动,简单、浏览器支持良好,但在IE6-版本支持存在问题。但是存在以下局限性,要适环境而用:

a) Overflow方式:滚动条会被隐藏,如果子内容超高则存在显示不全的问题;

b) Float方式:让父容器浮动,那么就存在对父容器同辈元素的影响;

c) Dipslay方式:让父容器变为table或者flex等,都存在不明确的影响,大家都不推荐使用。

2. 最佳解决方案:利用:after添加一个伪元素并给予clear:both和zoom:1来实现清除浮动,兼容性好,对环境影响最小。

相关推荐

自己剪頭髮10個技巧大公開

Ad Placement : keyvisualbeautySweet HomeHair自己剪頭髮10個技巧大公開|學會DIY家中打薄頭髮剪層次秘訣,新手都不怕失手!Charmian Li, Moe Kwok09 Mar 2023 Ad Pla

07-04 分类 365bet网页版

仰食是什么意思

yǎngshí 仰食 拼音yǎng shí 注音一ㄤˇ ㄕˊ 近义仰给 词语解释仰食[ yǎng shí ]⒈ 依靠他人而得食。 引证解释⒈ 依靠他人而得食。 引《后汉书·西

08-08 分类 365bet网页版

Portraiture怎么使用

Portraiture是一款智能型磨皮插件,可自动识别人像中的皮肤、头发、眉毛等区域,进行智能磨皮。这就意味着,我们无须花费时间为人像添加蒙

08-22 分类 365bet网页版

襟字的成语有哪些

掣襟露肘 chè jīn lù zhǒu 接一下衣襟胳膊肘儿就露出来。形容衣服破烂,生活贫困。 详细解释 正襟危坐 zhèng jīn wēi zuò 理好衣襟;端端正正地

07-21 分类 365bet官网是多少

为什么游戏重要?

收藏历史消息红游睹思为什么游戏重要?不同年龄段的人对于游戏的认知是截然不同的,但是游戏到底为什么重要? RED2016-03-11 本文系用户投稿

07-11 分类 365bet网页版

老款奔驰c200优缺点点评

提问 我要回答 我要提问 老款奔驰c200优缺点点评 最佳答案 fks1028 2022-10-13 19:27:34 2022款奔驰C级这个车个人认为优点是:1.内饰豪华;2.静谧性强;

07-29 分类 365bet网页版

铁螺栓回收价格(废旧螺栓回收)

大家好今天来介绍铁螺栓回收价格的问题,以下是万千紧固件小编对此问题的归纳整理,来看看吧。 国标螺丝螺母批发要多少钱一公斤 国标螺

07-21 分类 best365官网登录入口

手机dns哪个好

手机DNS选择可考虑阿里的223.5.5.5或腾讯的119.29.29.29,速度快且稳定。 手机DNS选择指南 一、国内常用公共DNS服务器推荐 DNS名称 首选DNS IP地址 备

08-17 分类 best365官网登录入口