下载鸥 > 网站下载 > 开发教程 > 前端开发

css清除浮动导致布局错乱的3个方法

357 2021-05-22 20:00:02

收藏
因为浮动会导致元素脱离标准流,导致其父元素出现一些看上去比较异常的现象。所以这里是几种防止浮动导致父元素表现异常的方法。
 

额外标签法

其实就是在容纳浮动的容器的最后添加一个具有clear属性的块级元素,如:
<div id="main_d">
    <div id="hd_box">
        <div class="ud_b hd_b">Hi</div>
        <div class="ud_b hd_b">Hi</div>
        <div class="ud_b hd_b">Hi</div>
        <div class="ud_b hd_b">Hi</div>
        <div style="clear:both;"></div>
    </div>
</div>

其中ud_b是加了左浮动的盒子。”hd_box”中的最后一个元素指定了”clear”属性,其作用是指定一个元素是否必须移动(清除浮动后)到在它之前的浮动元素下面。
 

给父元素添加overflow属性

给父元素添加overflow属性,就拿上面的代码来说,在id “main_d”中添加一条”overflow:hidden”就好。
不过这个方法有个缺点,就是无法显示溢出部分。

添加after伪类元素
先定义一个类:
.clearfix{
    /* IE6, 7 only */
    *zoom: 1;
}
.clearfix::after{
    content: "";
    display: block;
    height: 0;
    clear: both;
    visibility: hidden;
}

然后把”clearfix”这个类添加给父元素。
因为after是在使用该类的元素后面加一个内容,我们又把添加的这个内容设置成了block,即块元素,并对其添加了clear属性。所以这个方法其实相当于”额外标签法”。
 

双伪元素清除

.clearfix{
    /* IE6, 7 only */
    *zoom: 1;
}
.clearfix::before,
.clearfix::after{
    content: "";
    display: table;
}
.clearfix::after{
    clear: both;
}

这个方法和上面那个方法类似,但是你若问我为啥display是table而不是block,我只能回答你我也不知道为啥,但是block也是能用的。然而我看的教程里写的就是table,也没有解释为什么,所以我就只能当作”block在某些情况下也许有bug”处理。

本文转自gray-ice个人博客,原文链接防止子元素浮动导致父元素变化

本文地址:https://xzo.com.cn/develop/js/976.html

有帮助,很赞!

信息来源:gray-ice
导出教程 下载word版教程
发表评论 共有条评论
关于前端开发


JavaScript(简称“JS”) 是一种具有函数优先的轻量级,解释型或即时编译型的编程语言。JavaScript 基于原型编程、多范式的动态脚本语言,并且支持面向对象、命令式和声明式(如函数式编程)风格。

JavaScript十分强大,不管是前端页面开发、视觉动态渲染、数据交互还是后端逻辑处理,都可以通过JS实现。虽然它是作为开发Web页面的脚本语言而出名,但是它也被用到了很多非浏览器环境中。

推荐前端开发开发教程
JS怎样做倒计时效果?
JS怎样做倒计时效果?

在各种盛大的节日、活动前,网站制作倒计时特效可有效给活动页引流。那么,怎样...

1 444
Superslide响应式页面直接应用手机端技巧介绍
Superslide响应式页面直接应用手机端技巧介绍

如果是响应式网站,那么用superslide做轮播图需要做两个,这无疑是非常不方便的...

1 486
$(window).height() 和 $(document).height()有什么不同?
$(window).height() 和 $(document).height()有什么不同?

我们常用$(window).height() 和 $(document).height()来监听当前高度,但这个...

1 412
JS点击复制data-*属性(支持多个元素)
JS点击复制data-*属性(支持多个元素)

分享一段js原生点击复制data-*属性的源码,根据onclick事件触发,复制当前元素...

0 389
JS控制输入字数的两个方案
JS控制输入字数的两个方案

我们在文章输入框中经常有用到字数控制,但字数控制有两种方案,一种是字母/空...

0 399
jQuery监听点击事件弹出关注二维码教程
jQuery监听点击事件弹出关注二维码教程

通过jQuery实现点击关注按钮弹出二维码是一个比较常用的功能,今天鸥哥讲讲这...

0 500
JS判断苹果iPhone与iPad、安卓设备类型适配
JS判断苹果iPhone与iPad、安卓设备类型适配

在网站开发的过程中,一些涉及到资源下载的网站会通过判断不同系统手机来展示...

3 697
JS获取浏览器语言(中英文多语言站)并自动跳转代码
JS获取浏览器语言(中英文多语言站)并自动跳转代码

如果是多语言站点,主动获取浏览器默认语言并自动进行跳转可以有效降低跳出率...

0 991
推荐插件
帝国cms百度AI黑白图像上色api接口对接插件
帝国cms百度AI黑白图像上色api接口对接插件

百度开放了系列AI功能api如图像上色、图像去雾、图像修复、无损放大、清晰...

0 433
帝国cms批量添加后台用户插件
帝国cms批量添加后台用户插件

使用帝国cms的企业用户、新闻资讯类站点的用户很多,此类站点很多时候需要有...

0 782
帝国cms智能自动审核按星期几审核指定栏目带推送插件
帝国cms智能自动审核按星期几审核指定栏目带推送插件

采集站的必备资源是自动审核,要做到日收录也离不开定时发布。而本插件的自动...

0 1285
帝国cms纳米数据接口(足球比赛中最新数据)
帝国cms纳米数据接口(足球比赛中最新数据)

帝国cms 对接纳米数据(www.nami.com)接口,本接口主要接收、整理足球比赛实时数...

0 423
帝国cms百度AI图像清晰度增强api接口对接插件
帝国cms百度AI图像清晰度增强api接口对接插件

通过本插件,可以实现帝国cms网站对接百度云api实现图像清晰度增强的功能。经...

0 524
帝国cms百度AI图像无损放大api接口对接插件
帝国cms百度AI图像无损放大api接口对接插件

通过本插件,可以实现帝国cms网站对接百度云api实现图像无损放大的功能。经过...

0 453
帝国cms自动给正文关键词添加tag内链
帝国cms自动给正文关键词添加tag内链

帝国cms有自带的给关键词添加内链功能,但需要手动添加关键词,容易出现疏漏和...

0 840
帝国cms多栏目多数据表自动审核推送插件
帝国cms多栏目多数据表自动审核推送插件

本插件基于帝国cms帝国cms每日自动审核插件,在自动审核指定条数信息的基础上...

0 926
客服QQ:341553759
扫码咨询 常见问题 >
官方交流群:90432500
点击加入