HTML基础-04
定位
定位:通过定位可以将元素摆放在页面中任意位置
语法: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的更多相关文章
- javaSE基础04
javaSE基础04 一.三木运算符 <表达式1> ? <表达式2> : <表达式3> "?"运算符的含义是: 先求表达式1的值, 如果为真, ...
- javascript基础04
javascript基础04 1.循环语句 1.While 语句: while (exp) { //statements; } var i = 1; while(i < 3){ alert(i) ...
- Linux命令工具基础04 磁盘管理
Linux命令工具基础04 磁盘管理 日程磁盘管理中,我们最常用的有查看当前磁盘使用情况,查看当前目录所占大小,以及打包压缩与解压缩: 查看磁盘空间 查看磁盘空间利用大小 df -h -h: huma ...
- Linux基础04
** Linux基本操作常用命令(四) ** Linux系统管理命令 1.top:查看系统资源,每隔三秒刷新一次,按q:退出浏览状态 2.free:查看内存信息,-m,以MB单位显示 3.netsta ...
- Spring 框架基础(04):AOP切面编程概念,几种实现方式演示
本文源码:GitHub·点这里 || GitEE·点这里 一.AOP基础简介 1.切面编程简介 AOP全称:Aspect Oriented Programming,面向切面编程.通过预编译方式和运行期 ...
- Java入门 - 语言基础 - 04.对象和类
原文地址:http://www.work100.net/training/java-object-class.html 更多教程:光束云 - 免费课程 对象和类 序号 文内章节 视频 1 概述 2 J ...
- Java知识系统回顾整理01基础04操作符05赋值操作符
一.赋值操作 赋值操作的操作顺序是从右到左 int i = 5+5; 首先进行5+5的运算,得到结果10,然后把10这个值,赋给i public class HelloWorld { public s ...
- Java知识系统回顾整理01基础04操作符01算术操作符
一.算数操作符类别 基本的有: + - * / % 自增 自减: ++ -- 二.基本算数操作符 + - * / 基本的加 减 乘 除 public class HelloWorld { public ...
- python基础04 运算
数学运算 print 2+2 #加法 print 1.3-4 #剪法 print 3*5 #乘法 print 4.5/1.5 #除法 print 3**2 #乘方 print 10%3 #求 ...
- C#基础04
介绍:泛型介绍,索引,Foreach遍历的解释,yield方法,path文件操作,Directory类基本操作<目录> 一:泛型 百度资料:泛型是 2.0 版 C# 语言和公共语言运行 ...
随机推荐
- 查看锁信息 v$lock 和 v$locked_object
查看锁住的对象及会话id,serial# select a.* from (SELECT o.object_name, l.locked_mode, ...
- CUDA中关于C++特性的限制
CUDA中关于C++特性的限制 CUDA官方文档中对C++语言的支持和限制,懒得每次看英文文档,自己尝试翻译一下(没有放lambda表达式的相关内容,太过于复杂,我选择不用).官方文档https:// ...
- Jenkins链接Kubernetes集群
Jenkins CI/CD介绍 持续构建与发布是我们工作中必不可少的一个步骤,目前大多公司都采用Jenkins集群来搭建符合需求的CI/CD流程,然而传统的Jenkins Slave一主多从方式会存在 ...
- Nginx使用SSL模块配置https
背景 开发微信小程序,需要https域名,因此使用Nginx的SSL模块配置https 步骤 一.去域名管理商(如腾讯云.阿里云等)申请CA证书 二.在Nginx中配置,一般情况下域名管理商会提供配置 ...
- 前端学习(四):body标签(二)
进击のpython ***** 前端学习--body标签 接着上一节,我们看一下还有没有什么网址 果不其然,在看到新闻类的网址的时候 我们发现还有许多的不一样的东西! 使用ul,添加新闻信息列表 这个 ...
- PHP设计模式之----观察者模式
一.概述 1.观察者模式(Observer),当一个对象的状态发生改变时,依赖他的对象会全部收到通知,并自动更新. 2.场景:一个事件发生后,要执行一连串更新操作.传统的编程方式,就是在事件的代码之后 ...
- Android中的ANR问题
ANR:(Application Not Responding) 1.为什么会产生ANR 在Android中App的相应能力是由Activity Manager和Window Manager系统服务来 ...
- 关于if后有无else谜题
在自定义函数中 for(i=1;i<=6;i++) { if(a%i==0) return 0; else return 1; } 意思是,如果有一个除不尽就返回零,有一个除尽会立刻返回一. 如 ...
- Day03_SpringCloud2
学于黑马和传智播客联合做的教学项目 感谢 黑马官网 传智播客官网 微信搜索"艺术行者",关注并回复关键词"乐优商城"获取视频和教程资料! b站在线视频 0.学习 ...
- Python编程语言简介
Python诞生于20世纪90年代初,由荷兰人吉多·范罗苏姆发明.那么,Python这一门编程语言是如何发明的呢?这之中又有怎么的故事呢?请看下面. 故事发生在1989年的圣诞节上,吉多先生为了打发无 ...