zoukankan      html  css  js  c++  java
  • 一、CSS实现横列布局的方法总结

    一、使用float实现横列布局的方法

    如下面所示:DIV1和DIV2都可以选择向左或者向右浮动50%来实现展示在同一行

    div1 div2

    实现下面图片中布局的css样式如下:

    分析:

    1、第一行第一个图片和最后一个图片的左右边距是10px,中间图片的左右边距是5px。布局如下:

     <section class="active_div1">
            <div>
                <img id="active_div11" src="">
            </div>
            <div>
                <img id="active_div12" src="">
            </div>
            <div>
                <img id="active_div13" src="">
            </div>
        </section>
    .active_div1 div {
        float: left;
        width: 33.33%;
        box-sizing: border-box;
    }
     
    .active_div1 div:nth-child(1) {
        padding-left: 10px;
    }
     
    .active_div1 div:nth-child(3) {
        padding-right: 10px;
    }
     
    .active_div1 div:nth-child(2) {
        padding: 0 5px;
    }
     

     2、第二行只有中间图片的最有边距是5px;布局如下:

    <section class="active_div2">
            <div>
                <img id="active_div21" src="" onclick="imgClick(this)">
            </div>
            <div>
                <img id="active_div22" src="" onclick="imgClick(this)">
            </div>
            <div>
                <img id="active_div23" src="" onclick="imgClick(this)">
            </div>
        </section>
    .active_div2 div {
        width: 33.33%;
        float: left;
        box-sizing: border-box;
    }
     
    .active_div2 div:nth-child(2) {
        padding: 0px 5px;
    }

    注意:使用box-sizing: border-box后如果没有其他样式,所有的块将全部贴在一起,中间是没有任何间距的。这也是一个很经典的布局

    二、使用display:inline-block

    display:inline-block大多数用于行块的转换,不建议使用此属性来进行行列布局。因为inline-block不能完全代替float

    红框中的布局就是使用display:inline-block最经典的布局。

    <header id="consume_h">
           <span>已过期为消费不退款</span>
            <span>免预约</span>
    </header>
    .consume_h  span {
        display: inline-block;
    }
     
    .consume_h  span:before {
        content: "f120";
        display: inline-block;
        margin-right: 5px;
        margin-left: 10px;
        font-family: "Ionicons";
        speak: none;
        font-style: normal;
        font-weight: normal;
        font-variant: normal;
        text-transform: none;
        text-rendering: auto;
        line-height: 1;
        -webkit-font-smoothing: antialiased;
    }

    此处使用了伪类,关于伪类的定义是使用后面会有专门的笔记来记录,这里就不赘述了。

    此出还有一个经典的布局:

    这种布局一般是:
    <div>
                <img src="" alt="">
                <p>
        测试勿拍
                </p> 
    </div>

     使用定位position:absolute常用于左边固定,右边自适应的情况。

    1. 对div进行相对定位
    2. 对img进行绝对定位
    3. p进行相对定位
    注:固定宽度列的高度>自适应宽度列?

    三、使用flexible box实现 真正意义上的流体布局

    这种方法本人还没有真正在实际操作中体验过,此处先记录下来~
  • 相关阅读:
    HDU2897( 巴什博奕变形)
    HTML小知识点积累
    几种自己主动运行js代码的方式
    leetcode笔记:Contains Duplicate
    【Nutch基础教程之七】Nutch的2种执行模式:local及deploy
    为什么使用模板
    前端编程提高之旅(十)----表单验证插件与cookie插件
    【HDOJ 5399】Too Simple
    进程间通信之-信号signal--linux内核剖析(九)
    iOS类的合理设计,面向对象思想
  • 原文地址:https://www.cnblogs.com/gunelark/p/7284044.html
Copyright © 2011-2022 走看看