HTML/CSS -- 利用flexBox布局

语法规则可参考:RYF

布局1:高度固定,左宽度已知,右边适应

    <section>
        <style>
            .part2-content-wrap{
                display: flex;
                height: 100px;
            }
            .part2-content-left{
                width: 300px;
                background: red;
            }
            .part2-content-right{
                flex: 1;
                background: yellow;
                text-align: center;
            }
        </style>
        <article>
            <div class = "part2-content-wrap">
                <div class = "part2-content-left"></div>
                <div class = "part2-content-right">
                    <h1>利用flexbox布局</h1>
                    <p>高度固定,左宽度已知,右边适应</p>
                </div>
            </div>
        </article>
    </section>

同理可以实现,高度固定,右宽度已知,左边适应

 

布局2:高度固定,左右宽度已知,中间自适应

    <section>
        <style>
            .part1-content-wrap{
                display: flex;
                flex-wrap: nowrap;
                height: 100px;
            }
            .part1-content-left{
                 width: 300px;
                 background: red;
            }
            .part1-content-center{
                 flex: 1;
                 background: green;
                 text-align: center;
            }
            .part1-content-right{
                 width: 300px;
                 background: yellow;
            }
        </style>
        <article>
            <div class = "part1-content-wrap">
                <div class = "part1-content-left"></div>
                <div class = "part1-content-center">
                    <h1>利用flexbox布局</h1>
                    <p>高度固定,左右宽度已知,中间自适应</p>
                </div>
                <div class = "part1-content-right"></div>
            </div>
        </article>
    </section>

 

布局3:宽度已知,上下高度固定,中间自适应

    <style>
        .content-wrap{
            display: flex;
            flex-direction: column;
            width: 300px;
            height: 100%;
        }
        .content-top{
            height: 100px;
            background: red;
        }
        .content-center{
            flex: 1;
            background: yellow;
            text-align: center;
        }
        .content-bottom{
            height: 100px;
            background: green;
        }
    </style>
    <div class  = "content-wrap">
        <div class = "content-top"></div>
        <div class = "content-center">
            <h1>利用flexBox布局</h1>
            <p>宽度已知,上下高度固定,中间自适应</p>
        </div>
        <div class  = "content-bottom"></div>
    </div>

 

flex是css3推出的布局方法,功能非常强大,缺点是对老版浏览器不友好。

flex布局的强大远不止上面的简单布局,我们可以通过骰子布局来熟悉。

譬如这样的:

    <style>
        .content-wrap{
            display: flex;
            flex-direction: column;
            justify-content: space-between;
            align-items: center;
            width: 300px;
            height: 300px;
            border: 1px solid gray;
        }
        .item {
           width: 100px;
           height: 100px;
           border-radius: 50px;
           background: black;
        }
    </style>
    <div class  = "content-wrap">
        <div class ="item"></div>
        <div class ="item"></div>
    </div>

    <style>
        .content-wrap{
            display: flex;
            flex-direction: column;
            
            
            width: 300px;
            height: 300px;
            border: 1px solid gray;
        }
        .item {
           width: 100px;
           height: 100px;
           border-radius: 50px;
           background: black;
        }
        .item:nth-child(2) {
            align-self: center;
        }
    </style>
    <div class  = "content-wrap">
        <div class ="item"></div>
        <div class ="item"></div>
    </div>

我们可以把各种各样的都尝试一下,这样就能熟悉flexBox布局

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值