1.随便唠叨几句

 

这一节课我会对浮动元素和怎样清除浮动相关的技术进行一个讲解,同时,我会列举一些我们前端开发中常见的坑,希望大家以后不要在这些地方犯错。在开始今天的课程之前,有一个东西我需要先讲一下,学网页,我认为最最重要的就是学布局,如果一个网页,你不去布局,学再多的div加css也无济于事,你就算学了再多的特效,又能怎么样?那么,何为布局呢?很简单,就是一句话,把元素放在你想要放的地方,这个就是布局了。对于一些后台管理系统,其实最最常见的还是table布局,包括现在很流行的前端框架 - easyui,你去看他的源码,肯定也是table布局嘛。为什么会导致这样的情况发生呢,原因很简单,因为后台管理系统主要是给工作人员去做系统维护的,比如一个新闻发布网站,工作人员要发布一条新闻,那么就得登录后台管理系统,进入一个什么新闻管理的菜单,这些操作注重的是简单,易用,不需要有多么华丽的效果。所以,table布局还是有必要意义的。那么,我们在学习的过程中,是不是一定要把table布局弄得非常精通呢?这倒也不必,我们以后开发项目的时候,基本上还是要运用一些前端框架的,我们更多的,应该是去学会如何使用一个框架,而不是自己去造轮子。当然,等你以后成为技术大牛,造一点轮子也无妨。但是现在,没必要。

OK,废话不多说,开始吧,我已经用table画了一个简单的布局,你没必要去深究这些代码的含义,当然能看懂最好,看不懂也无伤大雅。反正以后我们不太可能自己去布局,都是用框架,嗯,就是这么回事。不过呢,如果要定制一些东西,那么还是需要div加css技术出马。

页面:

今天讲的东西,就在这个页面中实践。

 

2.无法想象,行内元素竟然这么任性,给了宽度和高度也不认帐!

 

额,是这样的哈,对于初学前端技术的萌新,往往都会在这一个地方吃亏,那就是给行内元素加了宽度和高度,怎么就没用呢?比如,我在A区域添加一个span元素。

然后,给它加一点样式:

再复习一遍,这个span元素的id是不是叫haha啊,那么我在给他设置样式表的时候,是不是要在前面要加一个#号呀?诶,就是这样的,如果这个span元素绑定了一个class属性,叫做xixi,那么前面加的就是一个点,应该是 “.xixi” ,不要混淆了。让我们来看一下效果:

我靠,郁闷的事情果然发生了,为什么加宽度和高度没有效果呀?呵呵,我相信很多人在这里吃过亏,不管怎么调就是没效果。原来,span是一个行内元素,而只有块级元素和行内块级元素才能够有自己的宽高,所以,我们给行内元素添加宽度和高度是没有效果的。解决方法有很多,最简单的,就是给这个span元素添加一个“display:block”或者“display:inline-block”的样式,就可以解决这个问题了。

效果:

接下来一个问题,我们已经给这个行内元素升级为行内块级元素了,如何让里面的字相对于这个span居中定位呢?首先,我们可以给它加一个text-align:center

然后,给它设置一个行高,和这个元素本身的高度相等

这样是不是就好了呀?嗯,这是今天第一个知识点。

 

3.震惊!P元素和div元素竟然这样,听说还有程序员不知道!

 

p元素是一个块级元素,所谓块级元素,就是那种会独自占满一行的元素,还有div也是块级元素。先来个例子吧。我现在要在B区域加一个P元素:

然后,我在这个p元素上挂载一个div元素:

看起来似乎没什么,让我们打开F12看看:

发现问题了吗,各位?本来是一个p元素,当我在它里面放一个div元素的时候,一个p元素竟然被分成了两个,同学们,这样是不是很危险啊?所以,我们一定要警惕这种写法,p元素被设计出来的本意,就是用来存放文本内容的,不能够用来布局,不然的话,可能会产生很多意想不到的BUG。布局,我们一般就用table,或者div、span,加上css就可以了。p元素就是用来存放文字的,明白了吗?

 

4.惊!多个div元素为了并排显示,连这种事都干得出!

 

接下来,我们来说一个非常非常重要的知识点,那就是浮动布局。那么,到底什么是浮动呢,还是以案例为主吧。我在B区域画三个div盒子,给他们都绑定同一个class,叫做box。

可以看到,div元素是块级元素,再复习一下啊,块级元素有什么特点啊,是不是会独自占满一行呀?所以,这三个div元素就没法在同一行显示了。那么,有没有什么办法,让多个块级元素在同一行显示呢?当然是有的,我们可以采用浮动布局,也就是说,让这些div元素“飘起来”,注意哦,飘起来以后,有两个方向,一个是向左漂浮,另一个则是向右漂浮。是的,只有这两种状态,没有第三种了。明白了吗,只有两种,要么往左边浮动,要么往右边浮动。

我们来尝试一下,让所有class为box的元素都往左边飘。

哇,是不是飘起来了。没错,这个就叫做浮动布局。我现在问一下大家,你觉得,浮动布局的目的是什么?没错,就是为了让块级元素在同一行上显示,仅此而已。没有其他更玄妙的说法了,不论多么复杂的网页,如果用到了浮动布局,肯定就是这么回事,肯定是为了让某些div元素在一行上面显示。在这个例子中,我们如果让第三个盒子往右浮动,就给它单独加一个行内样式:

现在,我还有个非常非常重要的知识点要交给大家,到底是什么呢?我们直接来个案例好不好?

我把这几个盒子换成span元素:

然后把浮动去掉:

页面就是这样的:

为什么呀,刚才我们是不是已经说了呀,当我们给一个行内元素设置宽度和高度,是不是没有用的呀?如果我们要让它生效,是不是要加一个“display:inline-block”或者“display:block”,就好了呀。那么,在这个例子中,我直接加上一个浮动定位:

刷新页面:

哇,天哪,怎么会这样?哦,原来,一旦我们给元素加了浮动定位,哪怕它是行内元素,也会默认转换成行内块级元素了。这也是一个比较重要的知识点,大家一定要记住。

 

5.惊!div元素因真爱成功私奔,还让空元素背锅,没WIFI也要看!

 

最后呢,我们要讲的,就是关于清除浮动的问题了,先来看下问题的由来。刚才,我们弄了三个div元素,都设置了float:left,于是,他们就脱离了原本的轨道,术语叫做脱离标准流。其实就是把自己的位置给腾出来了,来个例子吧。

首先,为了方便起见,我们把float:left,float:right这两个样式也封装一下,作为一个通用的工具样式,先把上一节课的tool.css拷贝过来:

然后,加上浮动的样式:

然后,在这个html文件中,引入tool.css:

这样的好处就是,我们不必单独写浮动的样式表了,在box中,把浮动样式删掉:

然后,在需要加浮动的地方,加上浮动的class:

诶,这样是不是也可以呢?好的,接下来,我在第三个盒子后面再加一个盒子:

注意哦,第四个盒子我没有加上左浮动,会有怎样的效果呢?看:

第四个盒子消失了,为什么呢?刚才我们说,当一个元素设置了浮动,那么就会飘起来,脱离标准流,也就是不占位置了。那么,在它后面的元素是不是就要紧跟上来啊?举一个现实生活中的例子,ABC三个人在排队买彩票,突然,B想到还有一件事情要做,就走了,那么C是不是要往前走一步,占据B的位置呀?注意哦,这个队伍就类似于标准流,现在B脱离了标准流,C是不是要跟上来,明白了吗?那么,在我们开发网页的时候,我们肯定不希望这样的事情发生吧,还记得我们当初采用浮动布局的目的是什么吗,是不是要让几个块级元素并排显示呀?现在虽然并排显示了,可是后面的元素自动顶上来,是不是布局就乱了呀?所以,我们需要清楚浮动。到底什么叫做清楚浮动呢,其实很简单,一句话的事:

清除浮动就是给飞出去的元素填坑,好让后面的元素不顶过来。这就是清除浮动,没有什么更加玄妙的东西了,就这么简单。

如何清除浮动呢?有一个办法就是在浮动定位的最后一个元素后面,加上一个空元素,比如div元素,里面啥也不写,然后加上一个叫做clear:both的样式,那么,浮动就被清除了。

刷新浏览器:

诶,是不是就好了呀?可是,你是否觉得,每次都这样去清除浮动的话,是不是会有很多个这样的空元素呀?这些空元素,仅仅是为了清除浮动而已,那么网页代码就显得有些乱。其实还有一种更好的方式,就是运用伪类,这是一个比较成熟的方式,也算是css中一种比较先进的技术,你就算看不懂也无所谓,只要会用就行。

我把这个样式也添加到了tool.css里面,然后,给需要清除浮动的那个元素添加上clearfix的class就OK了。比如,在这个例子中,我们就需要给三个盒子外面套一层div,加上clearfix的class,就可以了。以后我们都采用这种方式。

效果:

 

全文完。

源码下载地址:http://www.xiaotublog.com/getResourcePage.html?id=22
欢迎关注我的博客,长期更新各种JavaWeb相关的资料。

第五节 HTML&CSS -- 关于浮动和清除浮动的解说,以及两个大坑不要踩的更多相关文章

  1. css 浮动和清除浮动

    在写页面布局的过程中,浮动是大家经常用的属性.在好多的排版布局中都是用的的浮动比如说下面这些地方都是应用到了浮动. 在我学习浮动的时候可是熬坏了脑筋,在这里我分享一下我对浮动这块知识的总结. 一.浮动 ...

  2. 【转】CSS中的浮动和清除浮动

    以下转自<CSS中的浮动和清除浮动,梳理一下!> 浮动到底是什么? 浮动核心就一句话:浮动元素会脱离文档流并向左/向右浮动,直到碰到父元素或者另一个浮动元素.请默念3次! 浮动最初设计的目 ...

  3. [Web 前端] CSS篇之2. 清除浮动,什么时候需要清除浮动,清除浮动都有哪些方法

    cp: https://blog.csdn.net/zengyonglan/article/details/53304487 2. 清除浮动,什么时候需要清除浮动,清除浮动都有哪些方法 ? 一.什么时 ...

  4. 浅谈css中浮动和清除浮动带来的影响

    有很多时候,我们都会用到浮动,而我们有时候对浮动只是一知半解,却不是太清楚它到底是怎么回事,不知道各位有没有和我一样的感觉,只知道用它,却不知道它到底是怎么回事,所以,在学习的过程中,就要把一个概念不 ...

  5. CSS浮动与清除浮动(overflow)例子

    在css中浮动与清除浮动功能是我们开发中常用到的一个功能了,下面小编来为各位分析关于CSS浮动与清除浮动(overflow)例子吧. float脱离文本流,可是为什么文字却会有环绕的效果,这点实在是神 ...

  6. 重温前端基础之-css浮动与清除浮动

    文档流的概念指什么?有哪种方式可以让元素脱离文档流? 文档流,指的是元素排版布局过程中,元素会自动从左往右,从上往下的流式排列.并最终窗体自上而下分成一行行,并在每行中按从左到右的顺序排放元素.脱离文 ...

  7. CSS(7)--- 通俗讲解清除浮动

    CSS(7)--- 通俗讲解清除浮动 上一篇讲了CSS浮动 博客地址:CSS(6)---通俗讲解浮动(float) 一.理解清除浮动 1.为什么要清除浮动 我们前面说过,浮动本质是用来做一些文字混排效 ...

  8. CSS中如果实现元素浮动和清除浮动,看这篇文章就足够了

    浮动基本介绍 在标准文档流中元素分为2种,块级元素和行内元素,如果想让一些元素既要有块级元素的特点也同时保留行内元素特点,只能让这些元素脱离标准文档流即可. 浮动可以让元素脱离标准文档流,可以实现让多 ...

  9. CSS浮动和清除浮动

    1.浮动float div配合float浮动来做页面的布局,浮动最常用的地方就是用来做布局.只有一个标签设置了浮动float属性,就会变成块级标签. <!DOCTYPE html> < ...

  10. float浮动与清除浮动

    浮动: 浮动的框可以左右移动,直到它的边缘碰到包含框或另一个浮动框的边框为止.文档的普通流中的块框会当浮动框不存在一样.但会影响内联框(通常是文本)的排列. 属性值有:left,right,none; ...

随机推荐

  1. 【SPL标准库专题(6)】 Datastructures:SplPriorityQueue

    普通的队列是一种先进先出的数据结构,元素在队列尾追加,而从队列头取出.在优先队列中,元素被赋予优先级.当访问元素时,具有最高优先级的元素最先取出.优先队列具有最高级先出 (largest-in,fir ...

  2. 【EJB学习笔记】——EJB开发环境搭建(Eclipse集成JBoss)

    之前一直用的EJB开发环境是他们搭建好的,直接拿来用,不过还是感觉老吃别人嚼好的不太好吃,所以自己动手来玩一玩. EJB开发依赖的最基本的环境:JDK.Eclipse.JBoss,这里简单介绍一下最基 ...

  3. sudo控制权限简单用法介绍

    为了安全及管理的方便,可将需要用root权限的用户加入到sudo管理,用root的权限来管理系统.利用sudo控制用户对系统命令的使用权限. 普通用户可以查看,但不能删除: 但是在/tmp公共环境下可 ...

  4. python-异常处理try_except

    异常处理try-except 在我们写程序的时候经常会遇到一些异常或错误,导致程序终止 当我们使用计算器时,用10除以0会提示 一个简单的错误代码(10/0) a = 10 / 0 print(&qu ...

  5. python的学习之路day6

    大纲: 1.反射 其中的方法:getattr,delattr,setattr,hasattr __import__() __import__() 注意事项 2.模块中的特殊变量 __doc__ __c ...

  6. pychram使用技巧

    1.代码添加断点 点击对应行代码,按ctrl+F8,即可添加断点 2.查看内置函数的源码 点击对应函数后按crtl+B

  7. 【Alpha 冲刺】 7/12

    今日任务总结 人员 今日原定任务 完成情况 遇到问题 贡献值 胡武成 建立数据库 已完成 孙浩楷 完成作业列表界面 已完成 胡冰 完成作业展示页面 已完成 练斐弘 完成课件列表页面 未完成 时间不够 ...

  8. JAVA-最常用的A题语法

    输出 System.out.println(""); if 语句 if(布尔表达式) { //如果布尔表达式为true将执行的语句 } if...else... 语句 if(布尔表 ...

  9. PyQt5--QSlide

    # -*- coding:utf-8 -*- ''' Created on Sep 20, 2018 @author: SaShuangYiBing Comment: ''' import sys f ...

  10. PyQt5--QFileDiaglog

    # -*- coding:utf-8 -*- ''' Created on Sep 17, 2018 @author: SaShuangYiBing Comment: ''' import sys f ...