• css 布局方式


    星期六, 25. 三月 2017 11:41下午

    css 布局方式的总览

    图片来源 cssConf大会时阿里的 寒冬winter 老师

    css 布局的方式分为的部分

    css 的布局方式

    • 盒子内部的布局

      • 文本的布局
      • 盒子本身的布局
    • 盒子之间的布局 visual formmatting

      • 脱离正常normal flow的盒子的布局

        • absolute 布局上下文下的布局
        • float布局上下文下的布局、
      • 正常normal flow下的盒子的布局

        • BFC ( block formatting context ) 布局上下文下的布局
        • IFC 布局上下文下的布局
        • FFC 布局上下文下的布局
        • table 布局上下文下的布局
        • css grid 布局上下文下的布局

    1. 盒子内部的布局

    • 文本的布局
      * 有个line boxes包裹每行文字,这是看不见的;
      * line boxes 会取子元素最高的 line-height
      * 通过line-height 可以设置单行文本的水平的居中
    • box 布局
    图片的来源w3c

    2. 盒子之间的布局

    • absolute 布局 (脱离文档流)
    • float 布局 (脱离文档流)
    • normal flow (正常文档流的布局) (上下文)
      • bfc ( block formatting context ) 块级文档上下文

        • 满足下方任意一个条件,会为子元素,创建一个新的 bfc的上下文
          * 根元素 (body)
          * float 元素不为 none
          * overflow 不为 visible
          * display 为inline-block,table-cell,table-caption
          * postition 的值为 absolute , fixed
      • ifc (Inline formatting contexts ) 行内块级上下文

      • ffc ( Flex Formatting Contexts ) 伸缩格式化上下文

      • table ( table formatting context ) 表格布局上下文

      • grid ( grid formatting context ) 网格格式化上下文

    3. 需要的注意的地方

    • bfc上下文下的布局
      * float 布局的元素
      * 会被假装成行内元素进行布局,向浮动的方向挤,挤不开就会到第二行
      * 当与元素排在一行时,会先渲染 float的元素

            <div> 
                <span style = 'padding:10px'>  one  </span>
                <div  style = 'float:left' > left </div>
                <span>  two </span>
            </div>
      
       *  这个是效果图
      

    	* left 出现在了 one,two 的前方
    

    4. float布局

    • 浮动元素对周围元素造成的影响

      • 其他元素会环绕float的元素
      • 浮动元素可以设置外边距,不与周围元素的外边距重合
      • 生成块级框(display: block)
      • 浮动的元素顶部不能超过父元素的顶边
        • 可以设置 负的margin( margin: -10px) 来打破这条规则
    • 浮动元素的重叠问题
      出现的原因: 浮动元素可以设置 负的margin值,

      • 行内元素与浮动元素的重叠
        行内元素的内容,背景,边框都在浮动元素之上

      • 块框与浮动元素的重叠
        块框的背景,边框 会在浮动元素下方,内容在浮动元素上方

      • 浮动与浮动重叠
        后面的覆盖前面的

    • 父元素塌陷问题

        <div id = 'parent'> 
        	<div  style = 'float:left' > one  </div>
        </div>
      

      父元素没有高度,这样不能添加点击的事件,所以需要清楚浮动也可以给父元素设置高度

        <div id = 'parent' style = 'height : 200px'> 
        	<div  style = 'float:left' > one  </div>
        </div>
      
      • 清楚浮动的方式:
        1.添加一个子元素设置 clear : both

        <div id = 'parent' style = 'height : 200px'> 
        	<div  style = 'float:left' > one  </div>
        <div  style = 'clear:both' >  </div>
        

        2.给父元素添加一个伪类
        html部分

        <div id = 'parent' style = 'height : 200px'> 
        	<div  style = 'float:left' > one  </div>
        </div>
        

        css伪类

            .clearfix:before, .clearfix:after{
        		content : “”;
        		display : block;
        		overflow:hidden;
             }
  • 相关阅读:
    2022的pycharm创建项目的时候可以直接选择FastAPI了~
    玩转服务器博客两件套之绝佳的Markdown写作平台CodiMD
    使用 Spring Data JPA 按日期和时间查询实体
    Kafka 介绍
    页面置换算法
    与设备无关的I/O软件
    中断机构和中断处理程序
    磁盘存储器的性能和调度
    设备驱动程序
    缓冲区管理
  • 原文地址:https://www.cnblogs.com/kuachengshiyongbao/p/6619047.html
Copyright © 2020-2023  润新知