如何实现两列固定与一列自适应

六眼飞鱼酱① 提交于 2020-03-01 13:16:06

【逆战班】

1.flex布局

Flexible Box 模型,通常被称为 flexbox,是一种一维的布局模型。它给 flexbox 的子元素之间提供了强大的空间分布和对齐能力。我们说 flexbox 是一种一维的布局,是因为一个 flexbox 一次只能处理一个维度上的元素布局,一行或者一列。这里我们利用flex布局来实现两列固定一列自适应

<!DOCTYPE html>

<html lang="en">

<head>

    <meta charset="UTF-8">

    <meta name="viewport" content="width=device-width, initial-scale=1.0">

    <title>Document</title>

    <style> 

    #main{

         display: flex;/*设为伸缩容器*/

         }

    #left{ 

        width:200px;/*左侧固定宽度*/

        height:400px; 

        background:aqua;

    }

    #center{

         flex-grow:1; /*填满剩余空间*/ 

         height:400px;  

         background:green;}

    #right{ 

        width:200px;/*固定右侧宽度*/

        height:400px;  

        background:blue;

        }

    </style>

</head>

<body>

    <div id="main">

        <div id="left"></div>

        <div id="center"></div>

        <div id="right"></div>

    </div>

</body>

</html>

 

 

2.使用浮动方法

对左右两部分分别使用float:left和float:right,float使左右两个元素脱离文档流,中间元素正常在正常文档流中。对中间文档流使用margin指定左右外边距进行定位。

<!DOCTYPE html>

<html lang="en">

<head>

    <meta charset="UTF-8">

    <meta name="viewport" content="width=device-width, initial-scale=1.0">

    <title>Document</title>

    <style> 

    *{margin: 0;padding: 0;}

    #main{

         width: 100%;height: 400px;

         }

    #left{ 

        width:200px;/*左侧固定宽度*/

        height:400px;

        float: left; /*设置容器左浮动*/

        background:aqua;

    }

    #center{

         width: 100%;

         height:400px;

         margin: 0 200px;/*设置容器左右外边距*/ 

         background:green;}

    #right{ 

        width:200px;/*固定右侧宽度*/

        height:400px;  

        float: right;/*设置容器右浮动*/

        background:blue;

        }

    </style>

</head>

<body>

    <div id="main">

        <div id="left"></div>

        <div id="right"></div>

        <div id="center"></div>

    </div>

</body>

</html>

 

 

3.使用浮动加calc函数

对三部分使用float:left,然后左右两边固定宽度,中间使用calc函数计算宽度。

<!DOCTYPE html>

<html lang="en">

<head>

    <meta charset="UTF-8">

    <meta name="viewport" content="width=device-width, initial-scale=1.0">

    <title>Document</title>

    <style> 

    *{margin: 0;padding: 0;}

    #main{

         width: 100%;height: 400px;

         }

    #left{ 

        width:200px;/*左侧固定宽度*/

        height:400px;

        float: left; /*设置容器左浮动*/

        background:aqua;

    }

    #center{

         width: calc(100% - 400px);/*设置中间宽度为父容器宽度减去400px*/

         height:400px;

         float: left;/*设置容器左浮动*/ 

         background:green;}

    #right{ 

        width:200px;/*固定右侧宽度*/

        height:400px;  

        float:left;/*设置容器左浮动*/

        background:blue;

        }

    </style>

</head>

<body>

    <div id="main">

        <div id="left"></div>

        <div id="center"></div>

        <div id="right"></div>

    </div>

</body>

</html>

 

 

4.使用绝对定位

用绝对定位把左右两部分固定在两端,对中间文档流使用margin指定左右外边距进行定位。

<!DOCTYPE html>

<html lang="en">

<head>

    <meta charset="UTF-8">

    <meta name="viewport" content="width=device-width, initial-scale=1.0">

    <title>Document</title>

    <style> 

    *{margin: 0;padding: 0;}

    #main{

         width: 100%;

         height: 400px;

         position: relative;/*父容器使用相对定位*/

         }

    #left{ 

        width:200px;/*左侧固定宽度*/

        height:400px;

        position: absolute;/*左侧使用固定定位*/

        left: 0;/*定位在容器最左边*/

        top: 0;

        background:aqua;

    }

    #center{

         width:100%;

         height:400px;

         margin: 0 200px;/*设置中间容器左右外边距*/

         background:green;}

    #right{ 

        width:200px;/*固定右侧宽度*/

        height:400px;

        position: absolute;/*右侧使用固定定位*/

        right: 0;/*定位在容器最右边*/

        top: 0;

        background:blue;

        }

    </style>

</head>

<body>

    <div id="main">

        <div id="left"></div>

        <div id="center"></div>

        <div id="right"></div>

    </div>

</body>

</html>

 

 

效果图如下:

 

 

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!