三栏布局,顾名思义就是两边固定,中间自适应。三栏布局在开发十分常见,那么什么是三栏布局?例如当当网首页边商品导航和右边导航固定宽度,中间的主要内容随浏览器宽度自适应。效果如下图所示:

  

  下面围绕的这样的目的,即左右模块固定宽度,中间模块随浏览器变化自适应,想要完成的最终结果如下图:

  红色和蓝色宽度固定,绿色宽度自适应,下面七种方法实现的最终效果跟这个差不多,可能会稍有不同。

  方法一:流体布局(左右模块各自向左右浮动,并设置中间模块的 margin 值使中间模块宽度自适应。缺点就是主要内容无法最先加载,当页面内容较多时会影响用户体验。)

<!DOCTYPE html>

               <html lang="en">

<head>

<style>

.left {

float: left;

height: 200px;

width: 100px;

}

.right {

width: 200px;

height: 200px;

background-color: blue;

float: right;

}

.main {

margin-left: 120px;

margin-right: 220px;

height: 200px;

background-color: green;

}

</style>

</head>

<body>

<div class="container">

<div class="left">left</div>

<div class="right">right</div>

<div class="main">mian</div>

</div>

</body>

</html>

  方法二:BFC三栏布局(缺点跟方法一类似,主要内容模块无法最先加载,当页面中内容较多时会影响用户体验。)

<!DOCTYPE html>
<html lang="en">
<head>
<style>
.left {
float: left;
height: 200px;
width: 100px;
margin-right: 20px;
background-color: red;
}
.right {
width: 200px;
height: 200px;
float: right;
margin-left: 20px;
background-color: blue;
}
.main {
height: 200px;
overflow: hidden;
background-color: green;
}
</style>
</head>
<body>
<div class="container">
<div class="left"></div>
<div class="right"></div>
<div class="main"></div>
</div>
</body>
</html>

  方法三:双飞翼布局(利用的是浮动元素 margin 负值的应用。主体内容可以优先加载,HTML 代码结构稍微复杂点。)

   

<!DOCTYPE html>
<html lang="en">
<head>
<style>
.content {
   float: left;
   width: 100%;
}
.main {
   height: 200px;
   margin-left: 110px;
   margin-right: 220px;
  
}
    .left {
     float: left;
     height: 200px;
     width: 100px;
     margin-left: -100%;
     background-color: red;
    }
    .right {
     width: 200px;
     height: 200px;
     float: right;
     margin-left: -200px;
     background-color: blue;
    }   
</style>
</head>
<body>
<div class="content">
<div class="main"></div>
</div>
<div class="left"></div>
<div class="right"></div>
</body>
</html>
   方法四:圣杯布局(跟双飞翼布局很像,有一些细节上的区别,相对于双飞翼布局来说,HTML 结构相对简单,但是样式定义就稍微复杂,也是优先加载内容主体。)
 
<!DOCTYPE html>
<html lang="en">
<head>
<style>
    .container {
     margin-left: 120px;
     margin-right: 220px;
    }
    .main {
     float: left;
     width: 100%;
     height: 300px;
    
    }
    .left {
     float: left;
     width: 100px;
     height: 300px;
     margin-left: -100%;
     position: relative;
     left: -120px;
     background-color: blue;
    }
    .right {
     float: left;
     width: 200px;
     height: 300px;
     margin-left: -200px;
     position: relative;
     right: -220px;
     background-color: green;
    }
</style>
</head>
<body>
<div class="container">
    <div class="main"></div>
    <div class="left"></div>
    <div class="right"></div>
</div>
</body>
</html>
  方法五:flex布局(简单实用,未来的趋势,需要考虑浏览器的兼容性。)
      

<!DOCTYPE html>
<html lang="en">
<head>
<style>
    .container {
display: flex;
    }
    .main {
flex-grow: 1;
     height: 300px;
    
    }
    .left {
     order: -1;
     flex: 0 1 200px;
     margin-right: 20px;
     height: 300px;
     background-color: blue;
    }
    .right {
     flex: 0 1 100px;
margin-left: 20px;
     height: 300px;
     background-color: green;
    }
</style>
</head>
<body>
<div class="container">
    <div class="main"></div>
    <div class="left"></div>
    <div class="right"></div>
</div>
</body>
</html>
 
 
   方法六:table布局(缺点:无法设置栏间距)
    

<!DOCTYPE html>
<html lang="en">
<head>
<style>
.container {
     display: table;
     width: 100%;
}
.left, .main, .right {
     display: table-cell;
}
.left {
     width: 200px;
     height: 300px;
    
}
.main {
     background-color: blue;
}
.right {
     width: 100px;
     height: 300px;
     background-color: green;
}
</style>
</head>
<body>
<div class="container">
    <div class="left"></div>
    <div class="main"></div>
    <div class="right"></div>
</div>
</body>
</html>

    

  方法七:绝对定位布局(简单实用,并且主要内容可以优先加载。)
    

<!DOCTYPE html>
<html lang="en">
<head>
<style>
    .container {
     position: relative;
    }
    .main {
     height: 400px;
     margin: 0 120px;
    
    }
    .left {
     position: absolute;
     width: 100px;
     height: 300px;
     left: 0;
     top: 0;
     background-color: red;
    }
    .right {
     position: absolute;
     width: 100px;
     height: 300px;
     background-color: blue;
right: 0;
     top: 0;
    }
</style>
</head>
<body>
<div class="container">
<div class="main"></div>
    <div class="left"></div>
    <div class="right"></div>
</div>
</body>
</html>
 
 
 

css中常用的七种三栏布局技巧总结的更多相关文章

  1. 详解 CSS 七种三栏布局技巧

    作者:林东洲 链接:https://zhuanlan.zhihu.com/p/25070186 来源:知乎 著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 三栏布局,顾名思义就是 ...

  2. css中常用的几种居中方法

    在前端面试中,大都会问你div居中的方法: 文笔不好,就随便寥寥几句话概括了, 不过以后文笔肯定会变得更好一些的. 今天我们就细数一下几种方法: 1,使用position:absolute,设置lef ...

  3. 三种方法实现CSS三栏布局

    本文由云+社区发表 作者:前端林子 本文会分别介绍三种CSS实现三栏布局的方法,可在浏览器中打开查看效果 1.方法一:自身浮动的方法 实现方法:需要左栏向左浮动,右栏向右浮动,中间设左右margin来 ...

  4. css中,在高度已知,写出三栏布局,其中左栏、右栏宽度各位300px,中间自适应

    解决方案主要有五种 首先写入全局样式 <style type="text/css"> html * { margin: ; padding: ; } .layout { ...

  5. CSS实现三栏布局(5种)

    常见的布局方式: float布局.Position定位.table布局.弹性(flex)布局.网格(grid)布局 那么我们就是用以上5种方式完成三栏布局,不过前提是左右宽度(假如左右宽度为300px ...

  6. Css三栏布局自适应实现几种方法

    Css三栏布局自适应实现几种方法 自适应实现方法我们可以从三个方法来做,一个是绝对定位 ,自身浮动法 和margin负值法了,下面我们一起来看看这三个例子吧,希望例子能帮助到各位同学. 绝对定位法三栏 ...

  7. CSS三栏布局的四种方法

    总括: 不管是三栏布局还是两栏布局都是我们在平时项目里经常使用的,也许你不知道什么事三栏布局什么是两栏布局但实际已经在用,或许你知道三栏布局的一种或两种方法,但实际操作中也只会依赖那某一种方法,本文具 ...

  8. CSS系列,三栏布局的四种方法

    三栏布局.两栏布局都是我们在平时项目里经常使用的,今天我们来玩一下三栏布局的四种写法,以及它的使用场景. 所谓三栏布局就是指页面分为左中右三部分然后对中间一部分做自适应的一种布局方式. 1.绝对定位法 ...

  9. css 实现三栏布局的四种方式

    三栏布局就是左中右,左右两边固定,中间自适应. 1. 绝对定位 <div class="left">左边</div> <div class=" ...

随机推荐

  1. mvc自定义控件

    //自定义一个DatePicker.cshtml文件@helper Init() { <link href="~/Content/mobiscroll.custom-2.5.0.min ...

  2. HDU 1241 Oil Deposits (DFS or BFS)

    链接 : Here! 思路 : 搜索判断连通块个数, 所以 $DFS$ 或则 $BFS$ 都行喽...., 首先记录一下整个地图中所有$Oil$的个数, 然后遍历整个地图, 从油田开始搜索它所能连通多 ...

  3. [poj3565] Ants (二分图带权匹配)

    传送门 Description 年轻自然主义者比尔在学校研究蚂蚁. 他的蚂蚁以苹果树上苹果为食. 每个蚁群都需要自己的苹果树来养活自己. 比尔有一张坐标为 n 个蚁群和 n 棵苹果树的地图. 他知道蚂 ...

  4. 【codeforces 798A】Mike and palindrome

    [题目链接]:http://codeforces.com/contest/798/problem/A [题意] 让你严格改变一个字符,使得改变后的字符串为一个回文串; 让你输出可不可能; [题解] 直 ...

  5. 1103 N的倍数

    1103 N的倍数  题目来源: Ural 1302 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题  收藏  关注 一个长度为N的数组A,从A中选出若干个数,使得 ...

  6. 反射常用API

    反射所有功能都是通过class API来实现的 class常用API有: 1.class.GETINTERFACES():获得这个类实现的接口. 2.class.getMethods() Method ...

  7. ThinkPHP模版引擎之变量输出具体解释

    ThinkPHP模版引擎之变量输出具体解释 使用ThinkPHP开发有一定时间了,今日对ThinkPHP的模板引擎变量解析深入了解了一下.做出一些总结,分享给大家供大家參考. 详细分析例如以下: 我们 ...

  8. iOS 获取当前时间格式化字符串

    iOS 获取当前时间格式化字符串 太阳火神的漂亮人生 (http://blog.csdn.net/opengl_es) 本文遵循"署名-非商业用途-保持一致"创作公用协议 转载请保 ...

  9. 能够替代浮动的inline-block

    浮动有个缺点:脱离了原来的文档流,导致父容器无高度.使用inline-block不会脱离文档流.且无忘记清空浮动的困扰 并排的div都设置position:inline-block,vertical- ...

  10. ios开发之Swift新手入门

    1.关于swift和调试,swift在ios7.0才支持,ios8.3系统的真机必需要xcode6.3才干调试.安装xcode6.3需要os x 10.10以上 2.应用程序由Main.storybo ...