在CSS中BFC的作用有哪些,如何创建使用
Admin 2022-06-02 群英技术资讯 1036 次浏览
这篇文章给大家介绍了“在CSS中BFC的作用有哪些,如何创建使用”的相关知识,讲解详细,步骤过程清晰,有一定的借鉴学习价值,因此分享给大家做个参考,感兴趣的朋友接下来一起跟随小编看看吧。BFC
BFC:块级格式化上下文
BFC的布局规则
如何创建BFC
1、 float 的值不是 none 。
2、 position 的值不是 static 或者 relative 。
3、 display 的值是 inline-block 、 table-cell 、 flex 、 table-caption 或者 inline-flex
4、 overflow 的值不是 visible
BFC的作用
1.利用BFC避免margin重叠。
2.自适应两栏布局
3.清除浮动。
清除浮动
清除浮动主要是为了解决,父元素因为子级元素浮动引起的内部高度为0的问题。
清除浮动的方法
1. 额外标签法
在最后一个浮动标签后,新加一个标签,给其设置clear:both;(不推荐)
优点:通俗易懂,方便
缺点:添加无意义标签,语义化差
<style>
.div1 {
background: #00a2d4;
}
.left {
float: left;
width: 200px;
height: 200px;
background: #9889c1;
}
.right {
float: right;
width: 200px;
height: 200px;
background: orangered;
}
.clear {
clear: both;
}
</style>
</head>
<body>
<div class="div1">
<div class="left">Left</div>
<div class="right">Right</div>
<div class="clear"></div>
</div>
<div class="div2"></div>
</body>
2.父级添加overflow属性
通过触发BFC方式,实现清除浮动。(不推荐)
优点:代码简洁
缺点:内容增多的时候容易造成不会自动换行导致内容被隐藏掉,无法显示要溢出的元素
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style>
.div1 {
background: #00a2d4;
overflow: hidden;
}
.left {
float: left;
width: 200px;
height: 200px;
background: #9889c1;
}
.right {
float: right;
width: 200px;
height: 200px;
background: orangered;
}
</style>
</head>
<body>
<div class="div1">
<div class="left">Left</div>
<div class="right">Right</div>
</div>
<div class="div2"></div>
</body>
</html>
3.使用after伪元素清除浮动(推荐使用)
优点:符合闭合浮动思想,结构语义化正确。
缺点:ie6-7不支持伪元素:after,使用zoom:1触发hasLayout。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style>
.div1 {
background: #00a2d4;
}
.left {
float: left;
width: 200px;
height: 200px;
background: #9889c1;
}
.right {
float: right;
width: 200px;
height: 200px;
background: orangered;
}
.clearfix:after {
content: ""; /*内容为空*/
display: block; /*转换为块级元素*/
height: 0; /*高度为0*/
clear: both; /*清除浮动*/
visibility: hidden; /*隐藏盒子*/
}
.clearfix {
*zoom: 1; /*IE6\7的处理方式*/
}
</style>
</head>
<body>
<div class="div1 clearfix">
<div class="left">Left</div>
<div class="right">Right</div>
</div>
<div class="div2"></div>
</body>
</html>
4.使用before和after双伪元素清除浮动
优点:不仅可以清除浮动,也可以解决高度塌陷的问题(给父盒子添加类名clearfix)
缺点:用zoom:1触发hasLayout.
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style>
.div1 {
background: #00a2d4;
}
.left {
float: left;
width: 200px;
height: 200px;
background: #9889c1;
}
.right {
float: right;
width: 200px;
height: 200px;
background: orangered;
}
.clearfix:after, .clearfix:before {
content: "";
display: table;
}
.clearfix:after {
clear: both;
}
.clearfix {
*zoom: 1;
}
</style>
</head>
<body>
<div class="div1 clearfix">
<div class="left">Left</div>
<div class="right">Right</div>
</div>
<div class="div2"></div>
</body>
</html>
总结
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
本篇文章给大家介绍使用CSS的实用小技巧,了解一下CSS自动补全字符串的几种方法,希望对大家有所帮助!
css怪异盒模型的介绍:1、怪异盒设置的width/height不仅包含了content盒子内容的宽度/高度,还包含了padding和border的宽度/高度。2、一个块的总宽度= width + margin(左右)。
css背景样式包含:背景颜色“background-color”、背景图片“background-image”、背景定位“background-position”、背景重复“background-repeat”、“background”等。
这篇文章主要介绍了CSS3 filter(滤镜)实现网页灰色或者黑色模式的示例代码,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
css使图片自适应容器大小的效果怎么样做?在实际的项目中,我们往一个页面插入多张图片的话,可能会遇到图片尺寸不一致的问题,而一张张修改尺寸,效率太低,但如果直接设置图片的尺寸又可能会导致图片变形,这个时候使图片自适应容器大小就可以解决了。下面我们来看一下方法。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008