前端学习笔记之--CSS(3)

    盒模型:规定单个盒子的规则

    视觉格式化模型(布局规则):页面中的多个盒子排列规则

    视觉格式化模型,大体上将页面中盒子的排列分为三种方式:   常规流      浮动      定位

    常规流布局

     常规流、文档流、普通文档流、常规文档流

        所有元素,默认情况下,都属于常规流布局

        总体规则:块盒独占一行,行盒水平依次排列

        包含块(containing block):每个盒子都有它的包含块,包含块决定了盒子的排列区域。

        绝大部分情况下:盒子的包含块,为其父元素的内容盒

    块盒

        1.每个块盒的总宽度,必须刚好等于包含块的宽度

            宽度的默认值是auto

            margin的取值也可以是auto,默认值0

            auto:将剩余空间吸收掉

            width吸收能力强于margin

            若宽度、边框、内边距、外边距计算后,仍然有剩余空间,该剩余空间被margin-right全部吸收

            在常规流中,块盒在其包含快中居中,可以定宽、然后左右margin设置为auto。

    2.每个块盒垂直方向上的auto值

        height:auto, 适应内容的高度

        margin:auto, 表示0

    3.百分比取值

        padding、宽、margin可以取值为百分比

    以上的所有百分比相对于包含块的宽度。

    高度的百分比:

    1). 包含块的高度是否取决于子元素的高度,设置百分比无效     2). 包含块的高度不取决于子元素的高度,百分比相对于父元素高度

    4.上下外边距的合并

        两个常规流块盒,上下外边距相邻,会进行合并。

        两个外边距取最大值。

    


    浮动float

     视觉格式化模型,大体上将页面中盒子的排列分为三种方式:常规流    浮动    定位.

    应用场景    

     文字环绕        横向排列

    浮动的基本特点

     修改float属性值为:

        left:左浮动,元素靠上靠左

        right:右浮动,元素靠上靠右

    默认值为none

        当一个元素浮动后,元素必定为块盒(更改display属性为block)

        浮动元素的包含块,和常规流一样,为父元素的内容盒

    盒子尺寸

      宽度为auto时,适应内容宽度

      高度为auto时,与常规流一致,适应内容的高度  

      margin为auto,为0.

      边框、内边距、百分比设置与常规流一样

    盒子排列

     左浮动的盒子靠上靠左排列

     右浮动的盒子考上靠右排列

     浮动盒子在包含块中排列时,会避开常规流块盒

     常规流块盒在排列时,无视浮动盒子

     行盒在排列时,会避开浮动盒子

     外边距合并不会发生

    如果文字没有在行盒中,浏览器会自动生成一个行盒包裹文字,该行盒叫做匿名行盒。

    高度坍塌

     高度坍塌的根源:常规流盒子的自动高度,在计算时,不会考虑浮动盒子

        清除浮动,涉及css属性:clear

        默认值:none

        left:清除左浮动,该元素必须出现在前面所有左浮动盒子的下方

        right:清除右浮动,该元素必须出现在前面所有右浮动盒子的下方

        both:清除左右浮动,该元素必须出现在前面所有浮动盒子的下方

        

    

你可能感兴趣的:(前端学习笔记之--CSS(3))