1. 浮动

CSS float属性定义了元素在水平方向的浮动。该元素从网页的正常流动(文档流)中移除,对于浮动元素后的块级元素,块级元素将会被浮动元素覆盖,并且会接着其上一个文档流中的元素,按文档流的规则进行排列,即浮动元素不会影响紧随着它的块级元素的排列。对于接着浮动元素的行内元素(包块行内块元素),行内元素会环绕在浮动元素周围。浮动元素默认是行内块级元素,相邻浮动元素之间的元素排列也符合标准文档流。在CSS中,任何元素都可以设置成浮动元素。

特点

  • 行内元素环绕
  • 脱离标准文档流
  • 默认属于行内块元素
  • 浮动元素无法撑起父元素的高度
  • 未指定宽度时,浮动元素收缩成文本的宽度

父元素的塌陷

假设一个父元素中有若干个子元素,若其中有几个或全部子元素的属性都设置成浮动,而父元素没有设置高度。则会出现以下现象:

1)子元素全部设置成浮动元素,由于浮动元素无法撑起成父元素的高度,父元素的高度将会坍塌为0;

2)子元素中有一些元素设置成浮动元素,这些浮动元素也无法撑起父元素的高度,但剩下的非浮动元素可以撑起父元素,也就是说此时父元素的高度就其非浮动子元素按标准文档流排列时的高度。

浮动元素的清楚(解决父元素的坍塌)

有以下几种方式:

1)简单粗暴,给父元素设置宽高;但这个方法使用不灵活,后期维护不易,主要应用在网页中高度长时间不变的区域,比如导航栏。

2)内墙法:在最后一个浮动元素后面添加一个空的块级元素,并设置其属性clear: both; 。缺点:结构冗余。

3)伪元素(选择器)清楚法:给所有要清楚的浮动的父元素设置同一个类,对这个类的三个属性content, display, clear的值分别设置成 '', block, both。

4)把父元素的overflow的属性值设为:hidden。

浮动元素位置的调整

可通过margin调整位置,比如:50px; 50%(边框的位置在50%处)。

2. 定位

CSS position属性规定了元素的定位类型。不同的定位类型其位置的调整方式不同。

static

默认值,没有定位,元素会出现在正常的文档流中。

relative

相对定位,相对于其正常位置的定位,未脱离标准文档流。其后面的元素会接着它原来的位置,按标准文档流的形式排列下去;而其现在在页面上显示位置,并不会影响标准文档流的排列。

absolute

绝对定位,相对于除static定位外的第一个父元素的定位。绝对定位元素脱离了标准文档流,并且会覆盖在标准文档流上面

fixed

固定定位,相对于浏览器窗口左上角的定位。固定定位脱离了标准文档流,并且会覆盖在标准文档流上面。

定位元素位置的调整

可通过margin与top, bottom, left, right来调整,比如left:  50%; margin-left:  -50px; 。

z-index属性

z表示z轴,垂直于屏幕,并指向外;z-index表示在z轴上的位置,所以z-index大的元素会覆盖z-index小的元素,定位不为static的元素才有z-index属性。有两个要点:

1)如果z-index的值都设为auto,则后出现元素的z-index越大;

2)父级的z-index属性优先级更高,因为子元素是依附在父元素上的。

CSS float和position属性的更多相关文章

  1. DIV CSS布局中position属性用法深入探究

    本文向大家描述一下DIV CSS布局中的position属性的用法,position属性主要有四种属性值,任何元素的默认position的属性值均是static,静态.这节课主要讲讲relative( ...

  2. Css中的Position属性

    Css中的Position属性 Css属性在线查询地址: http://www.css88.com/book/css/properties/index.htm CSS 中的 position 属性 在 ...

  3. css的float和position属性

    (1)float的简单用法 <!DOCTYPE html> <html lang="en"> <head> <meta charset=& ...

  4. 详解css中的position属性

    这一次直接进入主题. css中最常用的布局类属性,一个是float,另一个就是定位属性position. 对于position来讲,有以下属性值: static : 无特殊定位,对象处于正常文档流.其 ...

  5. 【CSS学习】--- position属性

    一.前言 1.HTML中的三种布局方式: 标准流(普通流):网页中默认的布局方式,即顺序布局 浮动:float 定位:position 2.position属性的作用方式: 给position属性设置 ...

  6. css中关于position属性的探究(原创)

    关于position属性的设置,头脑中一直觉得不是很清楚,所以借助这次机会单独自己测试了一下,记作学习笔记.   首先,css的position属性包含下面四种设置情况: static:默认属性.指定 ...

  7. 对CSS中的Position属性的一些深入探讨

    转:http://www.cnblogs.com/coffeedeveloper/p/3145790.html Position属性 Position的属性值共有四个static.relative.a ...

  8. 浅谈css中的position属性

    我觉得吧,css如果不考虑浏览器的兼容问题的话,最让人头疼的应该就是position了,反正我是这么觉得的,为了能基本上搞清楚position的几种情况,我找了一些资料,做了一个小实验,下面是实验的过 ...

  9. 细说css中的position属性

    有过css开发经验的同学,对于position这个属性一定不会陌生,然而这个熟悉的属性确是面试题中的常客,也就说明了该属性在css的世界是有一定的江湖地位的,那么我们就来详细的说说position这个 ...

随机推荐

  1. 使用 kubeadm 安装 kubernetes v1.16.0

    近日通过kubeadm 安装 kubernetes v1.16.0,踩过不少坑,现记录下安装过程. 安装环境: 系           统:CentOS Linux release 7.6 Docke ...

  2. 云闪付个人免签支付用xposed解决强制升级

    云闪付的xposed程序之前用的是6.18的版本,前段时间突然不能用了,提示要升级到最新的7.0版本.之前这个云闪付的个人免签支付程序一直跑的挺好,云闪付也是所有免签支付里面最能跑量的,不甘就这么放弃 ...

  3. dos切换其他目录加参数/D

    D:\>cd /D c:\Windows c:\Windows> 不加参数/D 无法切换到另一个盘符

  4. SpringMVC 理论

    应用系统三层架构: C/S:客户端/服务器 B/S:浏览器/服务器 标准分层: 表现层:WEB 层,接受结果,响应结果,分发请求:通常客户端使用 http 协议请求 web 层,web 层需要接受 h ...

  5. Imagetragick 命令执行漏洞(CVE-2016–3714)

    Imagetragick介绍: ImageMagick是一款使用量很广的图片处理程序,很多厂商都调用了这个程序进行图片处理,包括图片的伸缩.切割.水印.格式转换等等.但近来有研究者发现,当用户传入一个 ...

  6. LeetCode109----链表转为二叉搜索树

    给定一个单链表,其中的元素按升序排序,将其转换为高度平衡的二叉搜索树. 本题中,一个高度平衡二叉树是指一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1. 示例:给定的有序链表: [-10, ...

  7. Twisted框架学习

    Twisted是用Python实现的基于事件驱动的网络引擎框架,是python中一个强大的异步IO库.理解twisted的一个前提是弄清楚twisted中几个核心的概念: reactor, Proto ...

  8. React Native初始化项目0.47.1报错

    首先看一下安卓和iOS报错: iOS终端运行报错: Xcode运行报错: 解决办法一: 将版本降到0.44.3,修改package,具体请看我的另一篇博客: http://www.cnblogs.co ...

  9. VS Code中内置终端运行C中文乱码问题

    环境:Win10 + VS Code + Code Runner插件 原因:VS Code默认文件编码为 UTF-8,生成的可执行文件也是UTF-8编码的,但是系统编码为 GB2312,所以程序中的中 ...

  10. 【CSS】如何在一个页面中引入样式css

    CSS(Cascading Style Sheet)又叫层叠样式表.是我们学习前端必不可少的一门语言,学习它其实就是为了学会如何去更改页面标签的样式.目前使用最广的是css3,但同样的,他是从css2 ...