美文网首页
如何利用flex布局实现各种布局

如何利用flex布局实现各种布局

作者: xiaoguo16 | 来源:发表于2017-08-28 16:38 被阅读0次

flex布局是一种很方便的布局,不用自己设置同行的div的高度相等,它们即可高度相等,并且可以方便的实现栅格系统等。下面是几种常见的布局,看flex如何实现:

两列等高布局:

左边固定宽度,右边占据剩余宽度:

<style>
    *{
        margin: 0;
        padding:0;
    }
    .grid{
        display: flex;
        border: 1px solid #ccc;
    }
    .gridCell1{
        background-color: #449fdb;
        flex-basis: 100px;
}
    .gridCell2{
        background-color: #3355D0;
        flex-basis:calc(100% - 100px);
    }
</style>
<body>
<div class="grid">
    <div class="gridCell1"><p>JS中没有块作用域的概念,所以下列的代码中的i可以在全局环境中访问,但这样会有一个弊端:污染了全局环境,因为在大型工程中,有可能会导致变量冲突。</p></div>
    <div class="gridCell2"><h1>标题</h1></div>
</div>
</body>

实现效果:

Paste_Image.png

可以看到上述代码实现了一个左边固定宽度,右边占据剩余宽度的布局,并且高度相等。
原理:设置父容器为flex,子元素中左边设置flex-basis属性宽度为固定宽度,另外一个子元素的flex-basis属性设置为100%减去这个固定宽度即可。

栅格系统:

在Bootstrap中可以很方便的使用栅格系统引入各个div的宽度划分,如果不使用栅格系统,利用flex也是很容易实现的。

<style>
    *{
        margin: 0;
        padding:0;
    }
    .grid{
        display: flex;
        border: 1px solid #ccc;
    }
    .gridCell1{
        background-color: #449fdb;
        flex: 1;
}
    .gridCell2{
        background-color: #3355D0;
        flex: 4;
    }
    .gridCell3{
        background-color: #b6d0ba;
        flex: 1;
    }
    .gridCell4{
        background-color: #d064b9;
        flex: 1;
    }
</style>
<body>
<div class="grid">
    <div class="gridCell1"><p>JS中没有块作用域的概念,所以下列的代码中的i可以在全局环境中访问,但这样会有一个弊端:污染了全局环境,因为在大型工程中,有可能会导致变量冲突。</p></div>
    <div class="gridCell2"><p>文字1</p></div>
    <div class="gridCell3"><p>文字2</p></div>
    <div class="gridCell4"><p>文字3</p></div>
</div>
</body>

效果图:

Paste_Image.png

如上,flex属性为flex-grow flex-shrink flex-basis的简写属性,当只有一个非负整数时,表示flex-grow的值,另外两个值为 1和0%;flex-grow是项目的放大比例,所以上述四个div的宽度以1:4:1:1的形式呈现。
另一种情况:flex属性为百分比的情况

<style>
    *{
        margin: 0;
        padding:0;
    }
    .grid{
        display: flex;
        border: 1px solid #ccc;
    }
    .gridCell1{
        background-color: #449fdb;
        flex: 10%;
}
    .gridCell2{
        background-color: #3355D0;
        flex: 40%;
    }
    .gridCell3{
        background-color: #b6d0ba;
        flex: 10%;
    }
    .gridCell4{
        background-color: #d064b9;
        flex: 40%;
    }
</style>
<body>
<div class="grid">
    <div class="gridCell1"><p>JS中没有块作用域的概念,所以下列的代码中的i可以在全局环境中访问,但这样会有一个弊端:污染了全局环境,因为在大型工程中,有可能会导致变量冲突。</p></div>
    <div class="gridCell2"><p>文字1</p></div>
    <div class="gridCell3"><p>文字2</p></div>
    <div class="gridCell4"><p>文字3</p></div>
</div>
</body>

效果图:

Paste_Image.png

当flex属性只有一个百分数时,表示的是flex-basis,其他的两个值flex-grow和flex-shrink均为0.

圣杯布局:

Paste_Image.png
<style>
    *{
        margin: 0;
        padding:0;
    }
    body{
        display: flex;
        flex-direction: column;
    }
    .header,.footer{
        flex: 1;
        background-color: #8591f7;
    }
    .container{
        flex:1;
        display: flex;
    }
    .left{
        flex-basis:100px;
        background-color: #449fdb;
    }
    .right{
        flex-basis: 100px;
        background-color: #3355D0;
    }
    .main{
        flex-basis: calc(100% - 200px);
        background-color: #6f7178;
    }
</style>
<body>
<div class="header"><h1>标题</h1></div>
<div class="container">
    <div class="left"><p>JS中没有块作用域的概念,所以下列的代码中的i可以在全局环境中访问,但这样会有一个弊端:污染了全局环境,因为在大型工程中,有可能会导致变量冲突。</p></div>
    <div class="main"><p>文字1</p></div>
    <div class="right"><p>文字2</p></div>
</div>
<div class="footer"><p>页脚</p></div>
</body>

该布局需要设置两个flex,一个垂直方向,一个水平方向,垂直方向的容器为body,水平方向的容器为container。垂直方向的三个子元素分别设置flex属性为1,水平方向的三个子元素分别各自设置flex-basis。

相关文章

  • 如何利用flex布局实现各种布局

    flex布局是一种很方便的布局,不用自己设置同行的div的高度相等,它们即可高度相等,并且可以方便的实现栅格系统等...

  • flex布局

    flex布局网页布局(layout)是 CSS 的一个重点应用。Flex 布局,可以简便、完整、响应式地实现各种页面布局

  • Flex布局

    什么是flex布局 2009年,W3C提出了Flex布局,它可以更简便,完整,响应式地实现各种页面的布局。Flex...

  • 初见FLEX

    FLEX布局 一种新的布局方式,flex布局 flex布局与方向无关 flex布局可以实现空间自动分配、自动对齐。...

  • flex布局学习笔记

    经典教程 Flex 布局教程:语法篇Flex 布局教程:实例篇flex布局游戏 理解 flex布局实现需要至少两层...

  • flex布局实现骰子

    学习flex布局后的实例布局--骰子具体实现原理可参考阮一峰的Flex 布局教程:实例篇和博客flex布局实现色子...

  • flex 布局

    flex 布局特点 块级布局侧重垂直方向、行内布局侧重水平方向,flex布局与方向无关 flex布局可以实现空间自...

  • React Native 之 flexbox布局

    flexbox布局是w3c继css之后的新的布局方式,可以简便、完整、响应式地实现各种页面布局。Flex是Flex...

  • 日常布局css

    一、如何实现子元素左右等高布局 grid布局 最简单 flex布局flex中的伸缩项目默认都拉伸为父元素的高度,也...

  • flex布局

    Flex布局特点 块级布局侧重垂直方向、行内布局侧重水平方向,flex布局是与方向无关的。 flex布局可以实现空...

网友评论

      本文标题:如何利用flex布局实现各种布局

      本文链接:https://www.haomeiwen.com/subject/mywwdxtx.html