移动Web开发--flex布局

听了B站一位老师的课,来记录下
一,传统布局和flex布局
传统布局:(div,css,浮动,定位等等)
兼容性好
布局繁琐
局限性,不能在移动端很好的布局
flex布局:
操作方便,布局简单
移动端应用广泛,PC端浏览器支持情况较差
IE11或更低版本不支持flex布局或者只支持一部分
比如:
PC端(baidu.com)
移动端(m.baidu.com)
建议:
如果是PC端,还是可以使用传统布局
如果是移动端或者是不用考虑兼容的PC使用flex较好
现阶段开发较老的话,比如说交通部政府部门等到I8以下要兼容的话,其他现在不用怎么考虑兼容
二,看一个例子
1.如果想实现三个div并排放的布局
在这里插入图片描述
然后就会

    <style>
        div {
            width: 350px;
            height: 300px;
            background-color: aqua;
        }
        
        div span {
            width: 100px;
            height: 100px;
            background-color: blueviolet;
        }
    </style>
</head>
<body>
    <div>
        <span>1</span>
        <span>2</span>
        <span>3</span>
    </div>
</body>

效果

添加inline-block解决的话

    <style>
        div {
            width: 250px;
            height: 300px;
            background-color: aqua;
            /* display: flex; */
        }
        
        div span {
            width: 100px;
            height: 100px;
            background-color: blueviolet;
            display: inline-block;
        }
    </style>
</head>

在这里插入图片描述

使用flex解决的话

    <style>
        div {
            width: 350px;
            height: 300px;
            background-color: aqua;
            display: flex; 
        }
        div span {
            width: 100px;
            height: 100px;
            background-color: blueviolet;
            /*display: inline-block;*/
        }
    </style>
</head>

在这里插入图片描述
三,flex布局原理
总结:通过给父盒子添加flex属性,来控制子盒子的位置和排列方式。
给父盒子设置flex后,子元素的float,clear和vertical失效。
3.1 对父元素设置:

  1. flex-direction: 决定主轴的方向(即项目的排列方向)
  2. flex-wrap: 决定容器内项目是否可换行
  3. flex-flow: flex-direction 和 flex-wrap 的简写形式
  4. justify-content:定义了项目在主轴的对齐方式
  5. align-items: 定义了项目在交叉轴上的对齐方式
  6. align-content: 定义了多根轴线的对齐方式,如果项目只有一根轴线,那么该属性将不起作用

3.1 对子元素设置:
order
flex-grow
flex-shrink
flex-basis
flex
align-self

3.2 一些例子
flex-direction : row默认从左到右排列、 row-reverse、column、column-reverse
justify-content:center,flex-start,flex-end,space-around(平分剩余空间),space-between(左右两边贴边,剩下平分)
面试问:flex-direction:row-reverse和justify-content:flex-end有什么区别
对比一下就知道了,注意看数字123的排列顺序。
flex-direction: row-reverse;
在这里插入图片描述
justify-content: flex-end;

在这里插入图片描述
justify-content: space-around;
在这里插入图片描述
justify-content: space-between;
在这里插入图片描述
flex-wrap: nowrap/wrap设置是否换行
align-items: center,stretch
设置水平垂直居中:

            display: flex;
            justify-content: center;
            align-items: center;

在这里插入图片描述
align-content: center
align-item和align-content的区别,align-item对单行,align-content设置多行

四:圣杯布局
另外:flex属性定义子项目分配剩余空间,用flex来表示占多少份数 用flex:1 表示剩下全占了
两边固定宽度,中间自适应布局,用flex:1 完事,easy
在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .container {
            background-color: rebeccapurple;
            display: flex;
        }
        
        .left {
            width: 100px;
            height: 100px;
            background-color: aquamarine;
        }
        
        .right {
            width: 100px;
            height: 100px;
            background-color: aqua;
        }
        
        .center {
            flex: 1;
            background-color: rebeccapurple;
        }
    </style>
</head>
<body>
    <div class="container">
        <div class="left">1</div>
        <div class="center">2</div>
        <div class="right">3</div>
    </div>
</body>
</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值