圣杯布局的实现过程

本文详细介绍了一种复杂的网页布局技巧——圣杯布局。该布局通过浮动、负边距和相对定位等技术实现三列布局,其中中间列宽度自适应,两侧为固定宽度。此布局方式能确保重要内容优先渲染,并且不需要添加额外的HTML标签。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

圣杯布局和双飞翼布局,它们都要求三列布局,中间宽度自适应,两边定宽,这样做的优势是重要的东西放在文档流前面可以优先渲染,而双飞翼布局是对圣杯布局的一种改良,下一篇会讲到。

圣杯布局:用到浮动、负边距、相对定位,不添加额外标签。

DOM结构:

<div class="header">Header</div>
<div class="bd">
    <div class="main">Main</div>
    <div class="left">Left</div>
    <div class="right">Right
    </div>
</div>
<div class="footer">Footer</div>

CSS样式:

    <style>
        body{padding:0;margin:0}
        .header,.footer{width:100%;  background: #666;height:30px;clear:both;}
        .bd{
            padding-left:150px;
            padding-right:190px;
        }
        .left{
            background: #E79F6D;
            width:150px;
            float:left;
            margin-left:-100%;
            position: relative;
            left:-150px;
        }
        .main{
            background: #D6D6D6;
            width:100%;
            float:left;

        }
        .right{
            background: #77BBDD;
            width:190px;
            float:left;
            margin-left:-190px;
            position:relative;
            right:-190px;
        }
    </style>

1.中间部分需要根据浏览器宽度的变化而变化,所以要用100%,这里设左中右向左浮动,因为中间100%,左层和右层根本没有位置上去。

       .left{
            background: #E79F6D;
            width:150px;
            float:left;
        }
        .main{
            background: #D6D6D6;
            width:100%;
            float:left;

        }
        .right{
            background: #77BBDD;
            width:190px;
            float:left;
        }

左浮动

2.把左层负margin150后,发现left上去了,因为负到出窗口没位置了,只能往上移。

     .left{
            background: #E79F6D;
            width:150px;
            float:left;
            margin-left:-150px;
        }

这里写图片描述

3.那么按第二步这个方法,可以得出它只要移动窗口宽度那么宽就能到最左边了,利用负边距,把左右栏定位。

        .left{
            background: #E79F6D;
            width:150px;
            float:left;
            margin-left:-100%;
        }

        .right{
            background: #77BBDD;
            width:190px;
            float:left;
            margin-left:-190px;
        }

这里写图片描述

4.然而问题来了,中间被左右挡住了,只好给外层加padding了。

       .bd{
            padding-left:150px;
            padding-right:190px;
        }

这里写图片描述

5.但是加了之后左右栏也缩进去了,于是采用相对定位的方法,各自相对于自己把自己移出去,得到最终结果。

        .left{
            background: #E79F6D;
            width:150px;
            float:left;
            margin-left:-100%;
            position: relative;
            left:-150px;
        }
        .right{
            background: #77BBDD;
            width:190px;
            float:left;
            margin-left:-190px;
            position:relative;
            right:-190px;
        }

这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值