CSS的三栏布局详解

这次给大家带来CSS的三栏布局详解,CSS的三栏布局的注意事项有哪些,下面就是实战案例,一起来看一下。

本文介绍了CSS经典三栏布局方案,分享给大家,也给自己做个笔记,具体如下:

三栏布局,顾名思义就是两边固定,中间自适应。三栏布局在开发十分常见

1. float布局

最简单的三栏布局就是利用float进行布局。首先来绘制左、右栏:

          .left {        float: left;        width: 100px;        height: 200px;        background-color: red;      }          .right {        float: right;        width: 100px;        height: 200px;        background-color: yellow;      }                

登录后复制

此时可以得到左右两栏分布:

CSS的三栏布局详解 

接下来再来看中间栏如何处理。我们知道对于float元素,其会脱离文档流,其他盒子也会无视这个元素。(但其他盒子内的文本依然会为这个元素让出位置,环绕在周围。)所以此时只需在container容器内添加一个正常的p,其会无视left和right,撑满整个container,只需再加上margin为left right流出空间即可:

         .left {        float: left;        width: 100px;        height: 200px;        background-color: red;      }          .right {        float: right;        width: 100px;        height: 200px;        background-color: yellow;      }          .main {        background-color: green;        height: 200px;        margin-left: 120px;        margin-right: 120px;      }          .container {        border: 1px solid black;      }          

登录后复制

CSS的三栏布局详解 

优势:简单

劣势:中间部分最后加载,内容较多时影响体验

2. BFC 规则

BFC(块格式化上下文)规则规定:BFC不会和浮动元素重叠。所以如果将main元素设定为BFC元素即可:

          .left {        float: left;        width: 100px;        height: 200px;        background-color: red;      }          .right {        float: right;        width: 100px;        height: 200px;        background-color: yellow;      }          .main {        background-color: green;        height: 200px;        overflow: hidden;      }          

登录后复制

3. 圣杯布局

圣杯布局的核心是左、中、右三栏都通过float进行浮动,然后通过负值margin进行调整。

第一步,先来看下基本布局

            .left {            float: left;            width: 100px;            height: 200px;            background-color: red;        }        .right {            float: left;            width: 100px;            height: 200px;            background-color: yellow;        }        .main {            float: left;            width: 100%;            height: 200px;            background-color: blue;        }                

登录后复制

CSS的三栏布局详解 

此时看到的效果是:左、右两栏被挤到第二行。这是因为main的宽度为100%。接下来我们通过调整左、右两栏的margin来将左、中、右放在一行中:

        .left {            float: left;            width: 100px;            height: 200px;            margin-left: -100%;            background-color: red;        }        .right {            float: left;            width: 100px;            height: 200px;            margin-left: -100px;            background-color: yellow;        }

登录后复制

第二步,将left的margin-left设置为-100%,此时左栏会移动到第一行的首部。然后再将right的margin-left设置为其宽度的负值:-100px,则右栏也会移动到和左、中栏一行中:

CSS的三栏布局详解 

不过此时还没有大功告成,我们试着在main中加入一些文字:

            

fjlskdjflkasjdfljasdljlsjdljsdjflksadj

登录后复制

CSS的三栏布局详解 

可以看到文字被压住了,接下来就要解决这个问题。

第三步,给container一个padding,该padding应该正好等于左、右栏的宽度:

        .container {            padding-left: 100px;            padding-right: 100px;        }

登录后复制

此时看到的结果是左、中、右三栏都整体收缩了,但文字依然被压住了。

CSS的三栏布局详解 

第四步,给左、右两栏加上相对布局,然后再通过设置left和right值向外移动:

        .left {            float: left;            width: 100px;            height: 200px;            margin-left: -100%;            position: relative;            left: -100px;            background-color: red;        }        .right {            float: left;            width: 100px;            height: 200px;            margin-left: -100px;            position: relative;            right: -100px;            background-color: yellow;        }

登录后复制

到此为止,大功告成:

CSS的三栏布局详解 

4. 双飞翼布局

双飞翼布局的前两步和圣杯布局一样,只是处理中间栏部分内容被遮挡问题的解决方案有所不同:

既然main部分的内容会被遮挡,那么就在main内部再加一个content,通过设置其margin来避开遮挡,问题也就可以解决了:

            .main {        float: left;        width: 100%;        }        .content {        height: 200px;        margin-left: 110px;        margin-right: 220px;        background-color: green;        }                .main::after {        display: block;        content: '';        font-size: 0;        height: 0;        clear: both;        zoom: 1;        }    .left {        float: left;        height: 200px;        width: 100px;        margin-left: -100%;        background-color: red;    }    .right {        width: 200px;        height: 200px;        float: left;        margin-left: -200px;        background-color: blue;    }           

登录后复制

唯一需要注意的是,需要在main后面加一个元素来清除浮动。

5. flex布局

flex布局是趋势,利用flex实现三栏布局也很简单,不过需要注意浏览器兼容性:

                    .container {                display: flex;                flex-direction: row;            }            .middle {                height: 200px;                background-color: red;                flex-grow: 1;            }            .left {                height: 200px;                order: -1;                margin-right: 20px;                background-color: yellow;                flex: 0 1 200px;            }            .right {                height: 200px;                margin-left: 20px;                background-color: green;                flex: 0 1 200px;            }                        

fsdfjksdjflkasjdkfjsdkljfklsjadfkljaksdljfskljffjksldfjldsfdskjflsdjfkljsdlfjsldjfklsjdkflj

登录后复制

有几点需要注意一下:

main要首先加载就必须写在第一位,但因为left需要显示在最左侧,所以需要设置left的order为-1

flex属性的完整写法是:flex: flex-grow flex-shrink flex-basis 。这也是flex实现三栏布局的核心,main设置flex-grow为1,说明多余空间全部给main,而空间不够时,仅缩小left right部分,同时因为指定了left right部分的flex-basis,所以指定了两者的宽度,保证其显示效果

6. 注意事项

绝对定位的方式也比较简单,而且可以优先加载主体:

                    .container {            }            .middle {                position: absolute;                left: 200px;                right: 200px;                height: 300px;                background-color: yellow;            }            .left {                position: absolute;                left: 0px;                width: 200px;                height: 300px;                background-color: red;            }            .right {                position: absolute;                right: 0px;                width: 200px;                background-color: green;                height: 300px;            }                        

fsdfjksdjflkasjdkfjsdkljfklsjadfkljaksdljfskljffjksldfjldsfdskjflsdjfkljsdlfjsldjfklsjdkflj

登录后复制

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

注意事项

注意事项

以上就是CSS的三栏布局详解的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2899312.html

(0)
上一篇 2025年3月10日 23:44:38
下一篇 2025年3月10日 23:44:53

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • css3的渐进增强和优雅降级

    这次给大家带来css3的渐进增强和优雅降级,css3渐进增强和优雅降级的注意事项有哪些,下面就是实战案例,一起来看一下。 渐进增强和优雅降级这两个概念是在 CSS3 出现之后火起来的。由于低级浏览器不支持 CSS3,但是 CSS3 特效太优…

    编程技术 2025年3月10日
    200
  • css怎样做出六边形图片

    这次给大家带来css怎样做出六边形图片,css做出六边形图片的注意事项有哪些,下面就是实战案例,一起来看一下。 本文主要介绍了css实现六边形图片的示例代码,分享给大家,具体如下: 不说别的,先上效果:   用简单的p配合伪元素,即可‘画出…

    2025年3月10日 编程技术
    200
  • CSS做出图片背景填充的六边形

    这次给大家带来CSS做出图片背景填充的六边形,CSS做出图片背景填充的六边形的注意事项有哪些,下面就是实战案例,一起来看一下。 六边形的实现原理其实就是通过旋转三个重叠的矩形得到的,如下图所示: 这里为了得到一个正的六边形,两个矩形旋转的角…

    2025年3月10日
    200
  • css中hover做遮盖罩闪动问题

    这次给大家带来css中hover做遮盖罩闪动问题,css中hover做遮盖罩的注意事项有哪些,下面就是实战案例,一起来看一下。 具体代码如下所示: 你好 登录后复制 这是html代码部分,原本想做一个遮盖罩的效果,当鼠标移动到p2的时候,p…

    2025年3月10日 编程技术
    200
  • CSS的mask-image属性详解

    这次给大家带来CSS的mask-image属性详解,使用CSS的mask-image属性注意事项有哪些,下面就是实战案例,一起来看一下。 CSS mask遮罩属性的历史非常久远了,远到比CSS3 border-radius等属性还要久远,最…

    2025年3月10日
    200
  • CSS3的rem(设置字体大小)使用教程

    这次给大家带来CSS3的rem(设置字体大小)使用教程,使用CSS3的rem(设置字体大小)的注意事项有哪些,下面就是实战案例,一起来看一下。 css3注意事项了相对单位 rem ,使用rem同em一样皆为相对字体大小单位,不同的是rem相…

    2025年3月10日
    200
  • CSS的loading动画效果使用教程

    这次给大家带来CSS的loading动画效果使用教程,CSS的loading动画效果使用注意事项有哪些,下面就是实战案例,一起来看一下。 本文介绍了一份纯CSS loading效果代码示例,分享给大家,具体如下: 预览 代码 使用了CSS的…

    2025年3月10日
    200
  • Css绘制扇形图案

    这次给大家带来Css绘制扇形图案,Css绘制扇形图案的注意事项有哪些,下面就是实战案例,一起来看一下。 阅读此文需具备基本数学知识:圆心角、弧度制、三角注意事项。 为实现如下效果呕心沥血: 当然你可以拥抱 Svg…在此分享如何纯…

    2025年3月10日 编程技术
    200
  • 纯css实现照片墙3D效果

    这次给大家带来纯css实现照片墙3D效果,纯css实现照片墙3D效果的注意事项有哪些,下面就是实战案例,一起来看一下。 直接上代码 1.准备材料: 准备材料就是没什么材料,自己麻溜赶快的去:百度找几张美女的照片来测试即可。 2.html代码…

    2025年3月10日
    200
  • CSS的滤镜实现火焰效果

    这次给大家带来CSS的滤镜实现火焰效果,CSS滤镜实现火焰效果的注意事项有哪些,下面就是实战案例,一起来看一下。 上次我们了解了一些css滤镜的基础知识,CSS滤镜 filter注意事项 这次我们就来用css的滤镜实现一个 火焰的效果。 解…

    2025年3月10日 编程技术
    200

发表回复

登录后才能评论