星空网 > 软件开发 > 网页设计

css:清除浮动

我们经常用伪类来清除浮动,比如这样

.clearfix:after {css:清除浮动 content: "";css:清除浮动 display: block;css:清除浮动 clear: both;css:清除浮动 height: 0;css:清除浮动}.clearfix {css:清除浮动 *zoom: 1;css:清除浮动}//hack IE6
我们来看一下样例:
<!DOCTYPE html><html><head>  <title></title>  <style>    *{      padding: 0px ;      margin: 0px ;    }    .block{      width: 100px ;      height: 100px ;      float: left ;      margin:10px;      border: solid 1px ;    }    .clearfix:after{      content: "" ;      display: block;      clear: both ;    }  </style></head><body><div class="clearfix">  <div class="block"></div>  <div class="block"></div>  </div>  <div class="block"></div>  <div class="block"></div></body></html>

本来四个格子是同行排列的,清除了浮动后就在清除浮动的地方换行了。

注意一定要是在父类添加清除浮动的clearfix类,如果不加在父类上是没有用的。我个人的理解是这样的,像before和after这样的伪类其实就是在元素内部的前面或后面添加一个元素,这样效果是一样的

<!DOCTYPE html><html><head>  <title></title>  <style>    *{      padding: 0px ;      margin: 0px ;    }    .block{      width: 100px ;      height: 100px ;      float: left ;      margin:10px;      border: solid 1px ;    }    .clear{      clear: both;    }  </style></head><body><div>  <div class="block"></div>  <div class="block"></div>  <div class="clear"></div>  </div>  <div class="block"></div>  <div class="block"></div></body></html>

但注意下面这样是不行的

<body>  <div class="block"></div>  <div class="block clearfix"></div>    <div class="block"></div>  <div class="block"></div></body>

还可以用overflow来清除浮动

<!DOCTYPE html><html><head>  <title></title>  <style>    *{      padding: 0px ;      margin: 0px ;    }    .block{      width: 100px ;      height: 100px ;      float: left ;      margin:10px;      border: solid 1px ;    }    .clear{      overflow: hidden;    }  </style></head><body><div class="clear">  <div class="block"></div>  <div class="block"></div>  </div>  <div class="block"></div>  <div class="block"></div></body></html>

 

清除浮动的另外一个原因就是要把浮动元素的父元素撑开,为什么用overflow能清除浮动我查到了以下这段话:
是因为overflow除了(visible)会重新给他里面的元素建立块级格式化(block formatting context)floats, position absolute, inline-block, table-cell和table-caption都不是块级样式,所以才会用到clear来控制浮动overflow也可以清除浮动是因为当在父级元素设置overflow时候,除了visible,就是只有auto, hidden或者scroll时候,也会建立新的块级格式给他的子元素, 从而起到清楚浮动效果具体信息可以在这里看虽然clear是旧的方式,但还是推荐用clear来做,有些情况会比overflow处理的要好.




原标题:css:清除浮动

关键词:CSS

CSS
*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: admin#shaoqun.com (#换成@)。

亚马逊新规定,以下9种电动交通设备上架需进行售前审核:https://www.kjdsnews.com/a/1666367.html
婚纱礼服行业的跨境机遇与挑战:https://www.kjdsnews.com/a/1666368.html
什么?你还不了解Reels是什么?一文带你解惑!!:https://www.kjdsnews.com/a/1666369.html
刚果(金)市场开发攻略,走进“非洲心脏”:https://www.kjdsnews.com/a/1666370.html
深度好文-亚马逊关键词的获取与关键词矩阵:https://www.kjdsnews.com/a/1666371.html
【更新】独立站“亿级大卖”11月份爆单推荐:https://www.kjdsnews.com/a/1666372.html
斥资210万美元,TikTok游说美国参议院阻止法案:https://www.goluckyvip.com/news/188213.html
大家推荐一下厦门三整天一个半天的旅游攻略:https://www.vstour.cn/a/365181.html
相关文章
我的浏览记录
最新相关资讯
海外公司注册 | 跨境电商服务平台 | 深圳旅行社 | 东南亚物流