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

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

370 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验证手机是否11位的做法
JS验证手机是否11位的做法

在网站表单提交前,我们往往需要验证一下信息避免错误数据,那么,怎样验证手机号...

1 432
jQuery怎样监听鼠标滚动是向上还是向下的状态?
jQuery怎样监听鼠标滚动是向上还是向下的状态?

知乎鼠标向下滚动显示文章标题,向上滚动显示栏目;又或者向下滚动到底部时异步...

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

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

1 498
JS获取当前时间、日期、星期并每秒更新一次
JS获取当前时间、日期、星期并每秒更新一次

很多网站上会有当前年月日、星期、时间的展示。这个展示用php做未免浪费性...

0 426
$(window).height() 和 $(document).height()有什么不同?
$(window).height() 和 $(document).height()有什么不同?

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

1 430
JS控制输入字数的两个方案
JS控制输入字数的两个方案

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

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

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

3 713
jQuery怎样给图片添加默认域名?
jQuery怎样给图片添加默认域名?

在很多网站中,图片的默认路径是相对于根目录的绝对路径,如果是其他站点引用,则...

0 464
推荐插件
帝国cms网站会员登录与退出历史记录日志插件
帝国cms网站会员登录与退出历史记录日志插件

帝国cms默认只有上次登录时间与ip,没有一个记录清单,所以今天,我们分享这个帝...

0 423
帝国cms访问统计ip地址链接与封禁插件下载
帝国cms访问统计ip地址链接与封禁插件下载

下载鸥开发了这款帝国cms封禁ip插件,自动记录访问情况,让我们可以更快的识别...

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

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

0 542
帝国CMS内网用户静态站点文章访客统计插件
帝国CMS内网用户静态站点文章访客统计插件

本插件适用于内网用户,可查看单篇文章访问者ip地址。如果添加访问者ip组,可查...

0 578
帝国cms自动生成文章新闻目录插件下载
帝国cms自动生成文章新闻目录插件下载

用户体验是我们的需求,百度蜘蛛的认可更是我们的需求。毕竟,没有收录排名,何来...

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

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

0 801
帝国cms百度AI图像去雾api接口对接插件
帝国cms百度AI图像去雾api接口对接插件

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

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

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

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