前端探索 | CSS定位

参考:饥人谷教育

div的分层

布局是屏幕平面上的,定位是垂直于屏幕的

div分层

背景范围:border外边沿围成的区域
浮动元素float脱离文档流,浮起了一点
在浮动元素上的文字是低于内联子元素的
在块级子元素上的文字与内联子元素,是按照先后出现顺序决定位置的,后出现的要高于先出现的

position

  • static

该关键字指定元素使用正常的布局行为,即元素在文档常规流中当前的布局位置。

HTML

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>position</title>
</head>
<body>
<div class="container">
     <div class="demo"></div>
</div>
</body>
</html>

CSS

.container{
    border: 1px solid red;
    height: 300px;
}
.demo{
    border: 1px solid green;
    width: 50px;
    height: 50px;
    position: static; //该关键字指定元素使用正常的布局行为,即元素在文档常规流中当前的布局位置。
}

效果


效果1
  • relative

该关键字下,元素先放置在未添加定位时的位置,再在不改变页面布局的前提下调整元素位置(因此会在此元素未添加定位时所在位置留下空白)。
进行元素的偏移(很少使用)
给absolute元素做爸爸(见下)
配合z-index,z-index:auto为默认值;当元素之间重叠的时候, z-index 较大的元素会覆盖较小的元素在上层进行显示。

HTML

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>position</title>
</head>
<body>
<div class="container">
     <div class="demo"></div>
     <div class="demo2"></div>
</div>
</body>
</html>

CSS

.container{
    border: 1px solid red;
    height: 300px;
}
.demo{
    border: 1px solid green;
    width: 50px;
    height: 50px;
    position: relative;//占位不变,显示偏移
    top: 10px;
    left: 10px;
}
.demo2{
    background: black;
    width:50px;
    height:50px;    
}

效果 (位移)


效果2

CSS

.container{
    border: 1px solid red;
    height: 300px;
}
*{box-sizing:borderbox;}
.clearfix:after{
  content:'';
  clear:both;
  display:both;
}
.demo{
    background:green;
    border: 1px solid green;
    width: 50px;
    height: 50px;
    position: relative;
    top:5px;
    //之后增加代码:z-index:1;
}
.demo2{
    background: black;
    width:50px;
    height:50px;
    position: relative;
}

原效果


原效果1

效果(增加z-index:1;)


效果3
  • absolute

元素会被移出正常文档流,并不为元素预留空间,通过指定元素相对于最近的非 static 定位祖先元素的偏移,来确定元素位置。绝对定位的元素可以设置外边距(margins),且不会与其他边距合并。

使用场景:
1.×关闭按钮;
2.鼠标悬浮提示

HTML

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>position</title>
</head>
<body>
<div class="container clearfix">
     <div class="demo"></div>
     <div class="demo2"></div>
     <span class="close">X</span>
</div>
</body>
</html>

CSS

.container {
  border: 1px solid red;
  height: 300px;
  position: relative;//作为爸爸,定位以此为基准
}
* {
  box-sizing: borderbox;
}
.clearfix:after {
  content: '';
  clear: both;
  display: both;
}
.demo {
  background: green;
  border: 1px solid green;
  width: 50px;
  height: 50px;
  position: relative;
  top: 5px;
  z-index: 1;
}
.demo2 {
  background: black;
  width: 50px;
  height: 50px;
  position: relative;
}
.close {
  position: absolute;//以上面的爸爸为基准进行定位
  top:0;
  right:0;
  padding: 0 10px;
  background:red;
  color:white;
}

效果(关闭按钮)


效果4

HTML

<!DOCTYPE html>
<html>

<head>
  <meta charset="utf-8">
  <title>position</title>
</head>

<body>
  <div class="container clearfix">
    <div class="demo"></div>
    <div class="demo2"></div>
    <span class="close">X</span>
    <div style="height:100px"></div>
    <button>点击
      <span class=tips>下一页</span>
    </button>
  </div>
</body>

</html>

CSS

.container {
  border: 1px solid red;
  height: 300px;
  position: relative;
  padding: 20px;
}
* {
  box-sizing: borderbox;
}
.clearfix:after {
  content: '';
  clear: both;
  display: both;
}
.demo {
  background: green;
  border: 1px solid green;
  width: 50px;
  height: 50px;
  position: relative;
  top: 5px;
  z-index: 1;
}
.demo2 {
  background: black;
  width: 50px;
  height: 50px;
  position: relative;
}
.close {
  position: absolute;
  top:0;
  right:0;
  padding: 0 10px;
  background:red;
  color:white;
}
button{
  position: relative;
}
button span{
  position: absolute;
  border: 1px solid black;
  white-space:nowrap; /*文字不换行*/
  bottom: calc(100% + 5px);/*设定具体位置*/
  left:50%;
  transform:translateX(-50%);/*居中显示*/
}
button span{
  display: none;/*默认为不可见*/
}
button:hover span{
  display: inline-block;/*悬浮时可见*/
}

效果


效果5
  • fixed

元素会被移出正常文档流,并不为元素预留空间,而是通过指定元素相对于屏幕视口(viewport)的位置来指定元素位置。元素的位置在屏幕滚动时不会改变。打印时,元素会出现在的每页的固定位置。fixed 属性会创建新的层叠上下文。当元素祖先的 transform, perspective 或 filter 属性非 none 时,容器由视口改为该祖先。

建议:移动端不要使用fixed
使用场景:

  1. 广告
  2. 回到顶部按钮

HTML

<!DOCTYPE html>
<html>

<head>
  <meta charset="utf-8">
  <title>position</title>
</head>

<body>
  <div class="container clearfix">
    <div class=fixed>△</div>
    
  </div>
</body>

</html>

CSS

.container {
  border: 1px solid red;
  height: 300px;
  position: relative;
  padding: 20px;
}
* {
  box-sizing: borderbox;
}
.clearfix:after {
  content: '';
  clear: both;
  display: both;
}
.fixed{
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 100px;
  border: 1px solid green;
  width: 100px;
  height: 100px;
}

.fixed{
  position: fixed;
  left: 10px;
  bottom: 10px;
}

效果


左下角返回顶部按钮
  • sticky

元素根据正常文档流进行定位,然后相对它的最近滚动祖先(nearest scrolling ancestor)containing block (最近块级祖先 nearest block-level ancestor),包括table-related元素,基于top, right, bottom, 和 left的值进行偏移。偏移值不会影响任何其他元素的位置。

该值总是创建一个新的层叠上下文(stacking context)。注意,一个sticky元素会“固定”在离它最近的一个拥有“滚动机制”的祖先上(当该祖先的overflowhidden, scroll, auto, 或 overlay时),即便这个祖先不是最近的真实可滚动祖先。这有效地抑制了任何“sticky”行为(详情见Github issue on W3C CSSWG)。

层叠上下文

层叠上下文
  • 每个层叠上下文都是一个沙盒(作用域)
  • 沙盒中的z-index与外面的世界无关
  • 处于同一沙盒的z-index才能进行比较

除了z-index: 0 还有哪些属性可以创建层叠上下文?

文档中的层叠上下文由满足以下任意一个条件的元素形成:

在层叠上下文中,子元素同样也按照上面解释的规则进行层叠。 重要的是,其子级层叠上下文的 z-index 值只在父级中才有意义。子级层叠上下文被自动视为父级层叠上下文的一个独立单元。
需要记忆的:z-index:0;flex;opacity<1;transform

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 200,527评论 5 470
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,314评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 147,535评论 0 332
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,006评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,961评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,220评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,664评论 3 392
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,351评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,481评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,397评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,443评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,123评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,713评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,801评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,010评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,494评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,075评论 2 341