CSS定位的那些小事儿

定位作为页面布局的一部分,对面设计页面至关重要.写了那么多的CSS却至今写不好定位?不要慌,今天我们就来总结一下CSS定位的那些小事情.

fixed

fixed 是 最为简单的了,一般而言,用了fixed很少出现问题.
fixed 以浏览器可视化的边界(即视口)为参考,以top,left等等作为偏移量.

.parent{
    height: 400px;
    width: 400px;
    background: #3d35ff;
}
.child{
    height: 200px;
    width: 200px;
    background: #1fff20;
}
/*fixed 以浏览器可视化的边界(即视口)为参考*/
.child{
    position: fixed;
    top: 300px;
    left: 300px;
}

absolute/relative/static/sticky

absolute:

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

relative:

该关键字下,元素先放置在未添加定位时的位置,再在不改变页面布局的前提下调整元素位置(因此会在此元素未添加定位时所在位置留下空白)。position:relative 对 table-*-group, table-row, table-column, table-cell, table-caption 元素无效

static:

该关键字指定元素使用正常的布局行为,即元素在文档常规流中当前的布局位置。此时 top, right, bottom, left 和 z-index 属性无效

sticky:

盒位置根据正常流计算(这称为正常流动中的位置),然后相对于该元素在流中的 flow root(BFC)和 containing block(最近的块级祖先元素)定位。在所有情况下(即便被定位元素为 table 时),该元素定位均不对后续元素造成影响。当元素 B 被粘性定位时,后续元素的位置仍按照 B 未定位时的位置来确定。position: sticky 对 table 元素的效果与 position: relative 相同。(可以用于固定导航在顶部和底部,中间部分可以滚动)

看一个sticky example:

<div class="nav">nav</div>
<div class="content">content</div>
<div class="footer">footer</div>

.nav{
    height: 50px;
    width: 100%;
    background: #41ff17;
    position: sticky;
    top:0;
}
.content{
    height: 1000px;
    width: 100%;
    background: #a7cbff;
}
.footer{
    height: 100px;
    width: 100%;
    background: #1fff20;
    position: sticky;
    bottom:0;
}

接着,总结以下,定位中的几个性质:
1.不设置position 时默认是 static.
2.relative是相对与第一个有定位的父级元素的边界的.不管是absolute,还是relative.
3.父元素浮动之后将不影响子元素定位,子元素依据父父元素定位.
4.margin-top/margin-left参考的边界不一样,对于margin-left: 参考的是包裹着他的parent(包括浮动),对于margin-top:参考的是第一级定位的parent,如果没有定位,则与包裹着的元素边界重叠.
5.上一层parent没有定位,parent 和 child的content 上边界是重叠的,margin-top取两者中较大的.
6.top,left和margin 是相互独立的.
7.为浮动时margin-top/margin-bottom 会合并成取其中较大的margin,margin-left/right 不会合并会求和;浮动之后margin-top/botom不相互影响.

<div class="parent">
      <div class="child">
        <div class="grandchild">grandchild</div>
      </div>
  </div>
.parent{
    margin: 100px 100px;
}
.child{
    margin: 50px 50px;
}
.parent{
    margin: 200px 100px;
    float:left
}
.child{
    margin: 100px 50px;
}

点这里看所有实践例子和截图.

以上.

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

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,725评论 1 92
  • CSS 是什么 css(Cascading Style Sheets),层叠样式表,选择器{属性:值;属性:值}h...
    崔敏嫣阅读 1,469评论 0 5
  • display:设置元素的显示方式 display:block(块级元素) 默认为父元素宽高,可设置宽高相对前序换...
    bluishwhiteC阅读 658评论 0 0
  • 17世纪,是满清耀武扬威的时代。 在这个世纪,满清打遍东亚无敌手,统一满洲各部,克朝鲜,吞蒙古,灭大明,平三藩,拒...
    Kukmoon谷月阅读 862评论 0 0
  • 姐姐出水痘,被圈在房间两周了,是班上第四个被传染者。高烧近40度,从出生到六年级虽说也有几次感冒流鼻涕啥的,这次是...
    文一川阅读 432评论 0 3