定位


定位:通过定位可以将元素摆放在页面中任意位置

语法:position属性设置元素的定位

可选值:static:默认值,开启定位

    relative开启相对定位

    absolute开启绝对定位

    fixed开启固定定位

相对定位:当元素设置position:relative;开启元素的相对定位

1           开启相对定位,元素不会发生任何变化

2           开启相对定位后,元素不会脱离文档流

3           相对定位的元素,是相对于其在文档流中的位置进行定位的

4           相对定位会使元素提升一个层级(可以遮盖其他块)

5           相对定位不会改变元素的性质,块还是块,行内还是行内

当元素开启定位后,可以通过四个方向的偏移量(offset)来控制元素的位置:

  top:元素与其定位位置的顶部距离

  bottom:元素与其定位位置的底部距离

  left:元素与其定位位置的左侧距离

  right:元素与其定位位置的右侧距离

绝对定位:(难点:参照物??)当元素设置position:absolute;开启元素的绝对定位

1           绝对定位会完全脱离文档流

2           绝对定位会改变元素的性质,行内变块,块宽高被内容撑开

3           开启绝对定位后若不设置偏移量,元素的位置不发生变化,位置还在那里

4           绝对定位会相对于离它最近的开启了定位的祖先元素进行定位

5           绝对定位会使元素提升一个层级(层级优先级:文档流<浮动<定位)

<div class=’box1’>

  <div class=’box2’>

  <div class=’box3’></div></div>

</div>

定位时的参照物:

  若box2设置absolute,box3与box2原点对齐;若box2未开,box1开,与box1对齐;否则与body对齐

若所有祖先元素都未开启绝对定位,则相对于HTML标签进行定位

一般情况,我们为一个元素开启绝对定位,会同时为它的父辈元素开启相对定位

绝对定位元素会相对于它的包含块进行定位

 

包含块:

  对于绝对定位元素来说,包含块就是离它最近的开启定位的块元素

  若没有开启定位的祖先元素,则其包含块是网页中的初始包含块(html为初始包含块)

开启绝对定位后,布局的公式新加入四个属性:

水平方向:

left+margin-left+border-left+padding-left+width+padding-right+border-right+margin-right+right=包含块的宽度

绝对定位元素水平方向布局的等式:auto+auto+0+0+200px+0+0+auto+auto=500px

垂直方向:

top+margin-top+border-top+padding-top+height+padding-bottom+border-bottom+margin-bottom+bottom=包含块的高度

  此时有五个值可设置为auto:left/right/margin-left/margin-right/width

在包含块中居中:

left:0;

right:0;

margin:0 auto;

全部居中(上下左右)

position:absolute;

left:0;

right:0;

top:0;

bottom:0;

Margin:auto;

固定定位:当元素设置position:fixed;开启元素的绝对定位

  特点与绝对定位一样,不同点:相对于浏览器的窗口(视口)进行定位

粘滞定位:电话部:王,李---粘滞其姓

.l1{

position:sticky;     l1标签的内容黏贴

top:0;

background-color:#bfa;

}

.l1{              l2标签的内容黏贴

position:sticky;

top:20px;

background-color:#bfa;

}

层级:开启定位元素会提升一个层级,定位元素层级可以同z-index来设置,z-index需要一个整数作为参数,值越大层级越高

父元素的层级再高,也不会盖住子元素;

若z-index的值相等,则后面元素会盖住前边元素;使用z-index时,需要开启 定位;

position:relative;

z-index:n;

设置不透明颜色度:方法一:opacity:0-1;(不,完全透)------0.5:半透明   元素整个透明(文字)

            方法二:rgba(0,0,0,0.5)                 只是颜色透明

HTML基础-04的更多相关文章

  1. javaSE基础04

    javaSE基础04 一.三木运算符 <表达式1> ? <表达式2> : <表达式3> "?"运算符的含义是: 先求表达式1的值, 如果为真, ...

  2. javascript基础04

    javascript基础04 1.循环语句 1.While 语句: while (exp) { //statements; } var i = 1; while(i < 3){ alert(i) ...

  3. Linux命令工具基础04 磁盘管理

    Linux命令工具基础04 磁盘管理 日程磁盘管理中,我们最常用的有查看当前磁盘使用情况,查看当前目录所占大小,以及打包压缩与解压缩: 查看磁盘空间 查看磁盘空间利用大小 df -h -h: huma ...

  4. Linux基础04

    ** Linux基本操作常用命令(四) ** Linux系统管理命令 1.top:查看系统资源,每隔三秒刷新一次,按q:退出浏览状态 2.free:查看内存信息,-m,以MB单位显示 3.netsta ...

  5. Spring 框架基础(04):AOP切面编程概念,几种实现方式演示

    本文源码:GitHub·点这里 || GitEE·点这里 一.AOP基础简介 1.切面编程简介 AOP全称:Aspect Oriented Programming,面向切面编程.通过预编译方式和运行期 ...

  6. Java入门 - 语言基础 - 04.对象和类

    原文地址:http://www.work100.net/training/java-object-class.html 更多教程:光束云 - 免费课程 对象和类 序号 文内章节 视频 1 概述 2 J ...

  7. Java知识系统回顾整理01基础04操作符05赋值操作符

    一.赋值操作 赋值操作的操作顺序是从右到左 int i = 5+5; 首先进行5+5的运算,得到结果10,然后把10这个值,赋给i public class HelloWorld { public s ...

  8. Java知识系统回顾整理01基础04操作符01算术操作符

    一.算数操作符类别 基本的有: + - * / % 自增 自减: ++ -- 二.基本算数操作符 + - * / 基本的加 减 乘 除 public class HelloWorld { public ...

  9. python基础04 运算

    数学运算 print 2+2  #加法 print 1.3-4 #剪法 print 3*5 #乘法 print 4.5/1.5 #除法 print 3**2   #乘方 print 10%3   #求 ...

  10. C#基础04

    介绍:泛型介绍,索引,Foreach遍历的解释,yield方法,path文件操作,Directory类基本操作<目录> 一:泛型   百度资料:泛型是 2.0 版 C# 语言和公共语言运行 ...

随机推荐

  1. Python Ethical Hacking - ARPSpoof_Detector

    ARPSPOOF_DETECTOR Watch value for gateway mac in the arp table Nice and simple, but will not detect ...

  2. 用Python把20年的GDP、人口以及房价数据进行了可视化

    前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. 作者:CDA数据分析师 提到一线城市,大家马上会想到北上广深这四个超级大都 ...

  3. Apache Tomcat目录结构与版本升级

    升级原因: 由于当前操作系统内的tomcat版本过低,存在大量高中危漏洞,存在一定的安全隐患.如下图所示,使用绿盟扫描器进行扫描爆出大量漏洞. 升级思路: 既然决定要升级,那么我觉得首先要做的就是自己 ...

  4. 一起学Blazor WebAssembly 开发(3)

    接着上篇,本篇开始讲下实现登录窗口,先看下大概的效果图: 打开的效果,没有美工美化 点登录校验得到不能为空 我在做blazor时用到了一个ui框架,这个框架名叫Ant Design blazor(ht ...

  5. 小特跨境电商ERP桌面版 1.不止包括进销存 还能算毛利

    经过近几年跨境电商ERP的开发,加上对跨境电商行业的业务积累,开发出一套适合中小跨境电商公司使用的ERP软件.欢迎选购.支持目前流行的各大电商平台,如速卖通.敦煌网.亚马逊.Shopee.Wish等. ...

  6. From 表单序列化为json对象(代码片段)

    $.fn.serializeJson=function(){ var serializeObj={}; var array=this.serializeArray(); $(array).each(f ...

  7. Go语言基础语法总结

    1. 认识HelloWorld 在前面的<Go的安装和使用>这篇文章中已经写过HelloWorld.go了,现在就来逐行认识一下它. package main import "f ...

  8. 面试题四十:数组中最小的k个数

    方法一:先排序后寻找前k个数: 方法二:受面试题三十九,寻找超过一半的数的启发,只把里面的middle改成k-1就行: void HalfNum( int [ ] Array ,int k){ int ...

  9. 谁能告诉我如何通过Jenkins完成分布式环境搭建并执行自动化脚本

    ​今天我们接着昨天的内容,看一看如何完成Jenkins分布式环境的搭建和使用,因为我之前也是自己一个人摸索的,如果有不对的地方,请各位看官私信指出. 新增分布式部署节点 在系统管理/节点管理中点击新建 ...

  10. Tomcat内部结构、工作原理、工作模式和运行模式

    TOMCAT的内部结构 Tomcat是一个基于组件的服务器,它的构成组件都是可配置的,其中最外层的是Catalina servlet容器,其他组件按照一定的格式要求配置在这个顶层容器中.Tomcat的 ...