CSS float和position属性
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属性的更多相关文章
- DIV CSS布局中position属性用法深入探究
本文向大家描述一下DIV CSS布局中的position属性的用法,position属性主要有四种属性值,任何元素的默认position的属性值均是static,静态.这节课主要讲讲relative( ...
- Css中的Position属性
Css中的Position属性 Css属性在线查询地址: http://www.css88.com/book/css/properties/index.htm CSS 中的 position 属性 在 ...
- css的float和position属性
(1)float的简单用法 <!DOCTYPE html> <html lang="en"> <head> <meta charset=& ...
- 详解css中的position属性
这一次直接进入主题. css中最常用的布局类属性,一个是float,另一个就是定位属性position. 对于position来讲,有以下属性值: static : 无特殊定位,对象处于正常文档流.其 ...
- 【CSS学习】--- position属性
一.前言 1.HTML中的三种布局方式: 标准流(普通流):网页中默认的布局方式,即顺序布局 浮动:float 定位:position 2.position属性的作用方式: 给position属性设置 ...
- css中关于position属性的探究(原创)
关于position属性的设置,头脑中一直觉得不是很清楚,所以借助这次机会单独自己测试了一下,记作学习笔记. 首先,css的position属性包含下面四种设置情况: static:默认属性.指定 ...
- 对CSS中的Position属性的一些深入探讨
转:http://www.cnblogs.com/coffeedeveloper/p/3145790.html Position属性 Position的属性值共有四个static.relative.a ...
- 浅谈css中的position属性
我觉得吧,css如果不考虑浏览器的兼容问题的话,最让人头疼的应该就是position了,反正我是这么觉得的,为了能基本上搞清楚position的几种情况,我找了一些资料,做了一个小实验,下面是实验的过 ...
- 细说css中的position属性
有过css开发经验的同学,对于position这个属性一定不会陌生,然而这个熟悉的属性确是面试题中的常客,也就说明了该属性在css的世界是有一定的江湖地位的,那么我们就来详细的说说position这个 ...
随机推荐
- solr系列之solr-5.5.5 window单机版jdk-1.7 tomcat8安装
一.Solr5.5.5.Tomcat8-x64.jdk-1.7-64单机部署 1.准备安装包,下载solr和tomcat的安装,直接解压即可(上篇一提供solr的下载路径) 2.在Solr5之前都还存 ...
- Lombok Pojo默认初始值问题
Lombok以注解形式来简化java代码,提高开发效率.比如我们常用的@Builder.@Data.@AllArgsConstructor.@NoArgsConstructor.@ToString等. ...
- iSCSI存储技术
iSCSI(Internet Small Computer System Interface),Internet小型计算机系统接口,又称为IP-SAN,是一种基于因特网及SCSI-3协议下的存储技术, ...
- Flutter移动电商实战 --(5)dio基础_引入和简单的Get请求
这篇开始我们学习Dart第三方Http请求库dio,这是国人开源的一个项目,也是国内用的最广泛的Dart Http请求库. 1.dio介绍和引入 dio是一个强大的Dart Http请求库,支持Res ...
- IDEA Method definition shorthands are not supported by current JavaScript version
sentinel-dashboard前端用到了AngularJS v1.4.8,在IDEA里修改js,触发js验证时有一些js文件会出现红色波浪线. 在代码行里鼠标一上去提示信息:Method def ...
- DeepLearningBook(中文版)书PDF
介绍深度学历基础理论.模型和应用.(738页). 第一部分 应用数学与机器学习基础,包括深度学习需要用到的线性代数.概率与信息论.数值计算.机器学习等内容. 第二部分 深度网络:现代实践,包括深度前馈 ...
- 使用redis防止重复提交
使用redis防止重复提交 其实主要思路是他的https://blog.csdn.net/u013378306/article/details/52944780 主要目前我的情况是,前后端分离的, ...
- smarty section 循环不同的四个样式
<div class="moban_spzs"> <{section name=goodslist loop=$strdata6}> <{if $sm ...
- Apple全系列缓冲区溢出内核RCE(CVE-2018-4407)poc
# CVE-2018-4407 ICMP DOS # https://lgtm.com/blog/apple_xnu_icmp_error_CVE-2018-4407 # from https://t ...
- Maven 官网 查找&下载 jar包& pom引用 完美方案
Maven 官网 查找&下载 jar包 & pom引用 问题描述 在我们在开发过程中,经常遇到程序中需要引用的某个版本jar包,但是在公司的私有仓库下载不到的情况. 遇到这种情况,该怎 ...