CSS定位

参考书籍:

    《编写高质量代码:web前端修炼之道》第四章

    《精通CSS:web高级标准解决方案》第三章

写在前面的话:

    1、css中的三种基本定位机制:

            a、普通流:元素框的位置由其在HTML中的位置确定。

            b、浮动。

            c、绝对定位。

    2、行内框在一行中水平排列,可以使用水平内边距、边框及外边距来设置他们的水平间距,但是,垂直内边距、边框及外边距不影响行内框的高度,同样,对行内框显示设置的高度或宽度也不会生效。

        由这一行所形成的框称为行框。行框的高度总是足以容纳它所包含的所有行内框(及由高度最高的行内框确定)。但是却可以设置该行框的行高line-height。所以修改行内框尺寸的方式:修改行高或者内边距、边框、外边距。

行框及行内框

         3、没有显示定义也会创建块级元素或者行框的情况:

                a、将一些文本添加到块级元素的开头(例如div),这些文本会形成匿名块框。

<div>

    sometextpppp

    <p>hello</p>

</div>

                b、对于块级元素的文本行,每行都会形成一个匿名行框,无法对匿名行框应用样式。

定位

写在前面的话:

        1、对于正常的文档流还有这样的一种表述方式:文档看起来是二维结构,但其实它是具有z轴的,并且由z-index来表示。默认情况下,元素都是处于z-index = 0 这一层。position:absolute/relative会激活元素的top,left,bottom,right和z-index属性(默认情况下这些属性是未激活的,设置了也不会生效)。

        2、设置了position:absolute/relative的元素会发生浮动,脱离z-index=0这一层,而float设置了浮动元素,但其仍处于z-index=0这一层,这也就是为什么浮动元素会影响到普通流中元素的布局。

        3、摘自MDNposition的原文

            If both top and bottom are specified (technically, not auto), top wins.

            If both left and right are specified, left wins when direction is ltr (English, horizontal Japanese, etc.)         and right wins when direction is rtl (Persian, Arabic, Hebrew, etc.).

(一)、相对定位:relative

        使用相对定位,元素仍占用他在普通文档流中的空间,然后相对与它在普通流中的位置进行定位。所以,移动该元素会覆盖其他的元素

relative

(二)、绝对定位:absolute

            1、绝对定位元素脱离了普通流,在普通流中不占据空间,普通流中的元素可视为该元素不存在。

            2、绝对定位元素相对于最近已定位(absolute/relative)父元素进行定位,如果不存在这样的元素,则该元素相对于画布或者HTML进行定位。

            3、因为它不占据普通流中的位置,所以它可能会覆盖其他元素,可以通过设置z-index来设置堆叠次序。

absolute

(三)、固定定位:fixed

    它是绝对定位的一种,不同的是它是相对于浏览器的视口进行定位。

(四)、浮动定位:float

            1、浮动的框可以左右移动,直到他的外边缘碰到包含框或者另一个浮动框。

            2、浮动元素会覆盖普通流中的元素。

            3、

向左浮动

            4、

 浮动的清理:

                    a、增加清除浮动元素;

                    b、触发包含元素的BFC;

                    c、给包含元素增加伪类:

                

(五)、static:默认的普通流的顺序

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

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,744评论 1 92
  • 定位 定位概况 CSS 有三种基本的定位机制:普通流、浮动和绝对定位。除非专门指定,否则所有框都在普通流中定位。 ...
    xiaolizhenzhen阅读 380评论 0 0
  • 块级元素,行内元素(内联元素) div、h1 或 p 元素常常被称为块级元素。这意味着这些元素显示为一块内容,即“...
    艳晓阅读 2,583评论 0 0
  • CSS 定位 CSS有三种基本的定位机制:普通流,浮动,绝对定位(absolute, fixed):普通流是默认定...
    _空空阅读 5,727评论 0 15
  • CSS定位(Positioning)允许你对元素进行定位。 CSS 定位和浮动 CSS 为定位和浮动提供了一些属性...
    廖马儿阅读 377评论 0 2