CSS基础:浅聊flex布局以及常用属性

news/2024/5/19 16:30:52 标签: css3, flex, align-self, align-content, flex-direction

前言

导语

流式布局,这个很简单也很容易理解,就是从上而下根据布局,然后依次通过元素进行布局即可,和web前面聊的网页开发没有什么大的区别,现在现在聊了一些flex布局,这个让流式布局中的一些布局进行优化。

借鉴一个网络途牛首页先看一下:

在这里插入图片描述

然后看一下其CSS源码:

在这里插入图片描述

一般为什么再pc端比移动版网页版要晚一些才能被广泛使用呢?因为这个需要新版本的浏览器才可以支持,而移动端前面也聊过对于兼容性要求相对要低。所以在移动端使用比pc端更加早以及广泛。

还是老规矩开始整代码演示,对于理论我不太喜欢阐述,而是先看代码效果,然后就明白其存在的牛逼之处。

体验

演示:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
<!--    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">-->
    <title>测试文档</title>
    <style>
    [class^="box"]{

        width: 800px;
        height: 600px;
        background-color: #4a90e2;
    }
    .box1{
     display: flex;
    }
         span{
            width: 200px;
            height: 200px;
            background-color: #55a532;
        }
    </style>
</head>
<body>
<div class="box1">
    <span>1</span>
    <span>2</span>
    <span>3</span>
</div>
<hr />
<div class="box2">
    <span>1</span>
    <span>2</span>
    <span>3</span>
</div>
</body>
</html>

在这里插入图片描述

如果这样看,就是简单一个赋予了子元素变成块内行元素而已啊,这个有什么可以吹的?浮动也可以啊,不就是在父类写了,然后子类浮动就不用在子元素中都写而已吗?

如果这样的话,那就是没有多少意义了。

如果添加一个属性呢?

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <!--    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">-->
    <title>测试文档</title>
    <style>
        [class^="box"]{

            width: 800px;
            height: 600px;
            background-color: #4a90e2;
        }
        .box1{
            display: flex;
            justify-content: space-around;
        }
        span{
            width: 200px;
            height: 200px;
            background-color: #55a532;
          

        }
    </style>
</head>
<body>
<div class="box1">
    <span>1</span>
    <span>2</span>
    <span>3</span>
</div>
<hr />
<div class="box2">
    <span>1</span>
    <span>2</span>
    <span>3</span>
</div>
</body>
</html>

在这里插入图片描述

flex__121">flex 布局原理

flexflexible box):弹性布局,用来为盒状模型提供最大的灵活性,任何一个容器都可以指定为flex布局。

注意:当我们为父类设为flex布局之后,子元素的float,clear和vertical-align属性失效。

所以说flex布局,用大白话说就是使用flex来进行页面布局。而这个属性是添加给父类盒子,来控制黑子的位置和排列方式。

flex布局中对父类常用的6个属性:

属性描述
flex-direction设置主轴的方向
justify-content设置主轴上子元素的排列方式
flex-wrap设置子元素是否换行
align-content设置侧轴上的子元素排列方式(多行)
align-items设置侧轴上的子元素排列方式(单行)
flex-flow复合属性,相当于flex-direction和flex-wrap

父类属性

flexflexdirection_146">flex设置主轴方向:flex-direction

flex布局中分为主轴和侧轴两个方向,也可以叫做行和列,或者x轴y轴。简单的说就是横和竖,默认横着是主轴,但是通过flex-direction进行从新划分。

在这里插入图片描述

演示:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <!--    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">-->
    <title>测试文档</title>
    <style>
        [class^="box"]{
              display: flex;
            width: 800px;
            height: 600px;
            background-color: #4a90e2;
        }
        .box1{

            flex-direction: column ;

        }
         .box3{

            flex-direction: row-reverse ;

        }

        span{
            width: 200px;
            height: 200px;
            background-color: #55a532;
            margin-left: 5px;

        }

    </style>
</head>
<body>
<div class="box1">
    <span>1</span>
    <span>2</span>
    <span>3</span>
</div>
<hr />
<div class="box2">
    <span>1</span>
    <span>2</span>
    <span>3</span>
</div>
<hr />
<div class="box3">
    <span>1</span>
    <span>2</span>
    <span>3</span>
</div>
</body>
</html>

在这里插入图片描述

flex_justfycontent_215">flex 设置主轴上子元素的排列:justfy-content

这个就使用到了justify-content属性:

在这里插入图片描述

在使用的之前一定要确定那个是主轴,不然就与自己想象中的结果有偏移,上面说的有些啰嗦,我简单是说一下:

属性值描述
flex-start默认值 从头部开始,主轴为x从左到右,主轴为y轴从上而下
flex-end从尾部来时列,与flex-start向反
center在主轴居中对齐,x轴就是水平居中,而y轴就是上下居中
space-around平分剩余空间
space-between先两边贴边,再平分剩余空间。

演示的时候,直接为x轴为主轴,不在分别演示如果是y轴的时候是什么情况。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <!--    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">-->
    <title>测试文档</title>
    <style>
        [class^="box"]{
            display: flex;
            width: 800px;
            height: 200px;
            background-color: #4a90e2;
        }
        .box1{
            justify-content: flex-start;
        }
        .box2{
            justify-content: flex-end;
        }
        .box3{
            justify-content: center;
        }
        .box4{
            justify-content: space-around;
        }
        .box5{
            justify-content: space-between;
        }
        span{
            width: 200px;
            height: 200px;
            background-color: #55a532;
            margin-left: 5px;

        }

    </style>
</head>
<body>
<div class="box1">
    <span>1</span>
    <span>2</span>
    <span>3</span>
</div>
<hr />
<div class="box2">
    <span>1</span>
    <span>2</span>
    <span>3</span>
</div>
<hr />
<div class="box3">
    <span>1</span>
    <span>2</span>
    <span>3</span>
</div>
<hr />
<div class="box4">
    <span>1</span>
    <span>2</span>
    <span>3</span>
</div>
<hr />
<div class="box5">
    <span>1</span>
    <span>2</span>
    <span>3</span>
</div>
</body>
</html>

在这里插入图片描述

flex_flexwrap_310">flex的子元素是否换行 :flex-wrap

这个就使用到了flex-wrap这个属性。

具体如下:

在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <!--    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">-->
    <title>测试文档</title>
    <style>
        [class^="box"]{
            margin-bottom: 500px;
            display: flex;
            width: 800px;
            height: 200px;
            background-color: #4a90e2;
        }
        .box1{
             flex-wrap: nowrap;
        }
        .box2{
            flex-wrap: wrap;
        }
        .box3{
            flex-wrap: wrap-reverse;
        }
        span{
            width: 300px;
            height: 200px;
            background-color: #55a532;
            margin-left: 5px;

        }

    </style>
</head>
<body>
<div class="box1">
    <span>1</span>
    <span>2</span>
    <span>3</span>
</div>
<hr />
<div class="box2">
    <span>1</span>
    <span>2</span>
    <span>3</span>
</div>
<hr />
<div class="box3">
    <span>1</span>
    <span>2</span>
    <span>3</span>
</div>

</body>
</html>

在这里插入图片描述

注意:flex布局中,默认子元素是 不换行的,如果不换行的话,而父类盒子装不下的话,就会缩小元素的宽度,放到父元素里面

单行控制侧轴的排序:align-items

前面可以通过justify-content属性,来控制主轴是否居中或者靠近后面等,自然不能满足我们的需求的是,还是需要控制侧轴的位置。

在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <!--    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">-->
    <title>测试文档</title>
    <style>
        [class^="box"]{
            margin-bottom: 500px;
            display: flex;
            width: 800px;
            height: 600px;
            background-color: #4a90e2;
            justify-content: center;
        }
        span{
            width: 300px;
            height: 200px;
            background-color: #55a532;
            margin-right: 5px;

        }

        .box1{
            flex-wrap: nowrap;
            align-items: center;
        }
        .box2{
            flex-wrap: wrap;
            align-items: center;
        }


        .box3{
            /* 使用拉伸那子盒子就不能给高度了*/
            align-items: stretch;
        }
        .box3 span{
            width: 300px;
            /* 使用拉伸那子盒子就不能给高度了*/
            height: auto;
            background-color: #df5000;
            margin-right: 5px;
        }

    </style>
</head>
<body>
<div class="box1">
    <span>1</span>
    <span>2</span>
    <span>3</span>
    <span>4</span>
</div>
<hr />
<div class="box2">
    <span>1</span>
    <span>2</span>
    <span>3</span>
    <span>4</span>
</div>
<hr />
<div class="box3">
    <span>1</span>
    <span>2</span>
    <span>3</span>
    <span>4</span>
</div>

</body>
</html>

在这里插入图片描述

但是如果上图中第二个图,让四个盒子一起居中对齐呢,这样动画align就无法实现了,所以就需要一个多行的排序align-content

多行控制侧轴的排序:align-content

这个是多行的对齐:

在这里插入图片描述

其实这个说是多行这个应该和justfy-content相对应一个主轴一个侧轴。

设置子元素在侧轴排列方式,并且只能用于子元素出现换行(多行)的情况下,其在单行是没有效果的。

属性值描述
flex-start默认值 从头部开始,侧轴为x从左到右,侧轴为y轴从上而下
flex-end从尾部来时列,与flex-start向反
center在侧轴居中对齐,x轴就是水平居中,而y轴就是上下居中
space-around平分剩余空间
space-between先两边贴边,再平分剩余空间。

演示:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <!--    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">-->
    <title>测试文档</title>
    <style>
        [class^="box"]{

            display: flex;
            flex-wrap: wrap;
            width: 800px;
            height: 600px;
            background-color: #4a90e2;

        }
        span{
            width: 300px;
            height: 200px;
            background-color: #55a532;
            margin-right: 5px;

        }

        .box1{
           align-content: flex-start;
        }
        .box2{

         align-content: flex-end;
        }
        .box3{

            align-content: center;
        }
        .box4{

            align-content: space-around;
        }
        .box5{

            align-content: space-between;
        }


    </style>
</head>
<body>
<div class="box1">
    <span>1</span>
    <span>2</span>
    <span>3</span>
    <span>4</span>
</div>
<hr />
<div class="box2">
    <span>1</span>
    <span>2</span>
    <span>3</span>
    <span>4</span>
</div>
<hr />
<div class="box3">
    <span>1</span>
    <span>2</span>
    <span>3</span>
    <span>4</span>
</div>
<hr />
<div class="box4">
    <span>1</span>
    <span>2</span>
    <span>3</span>
    <span>4</span>
</div>
<hr />
<div class="box5">
    <span>1</span>
    <span>2</span>
    <span>3</span>
    <span>4</span>
</div>

</body>
</html>

在这里插入图片描述

flexflow_579">复合写法flex-flow

前面也说了flex-flow属性是flex-direction和flex-wrap属性的复合属性。

flex-flow:row wrap;

这个就不在演示比了,毕竟很容易理解就是一个复合写法而已。

子元素属性

flex_591">flex后面加数字

flex后面添加一个数字就是占剩下的份数,而总分数就是子元素相加。简单演示:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <!--    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">-->
    <title>测试文档</title>
    <style>
        [class^="box"]{

            width: 800px;
            height: 600px;
            background-color: #4a90e2;
        }
        .box1{
            display: flex;

        }
        span{
            /* 可以看出这个宽度就意义了*/
            width: 200px;
            height: 200px;
            background-color: #55a532;
            margin-left: 5px;
            flex: 1;


        }
    </style>
</head>
<body>
<div class="box1">
    <span>1</span>
    <span>2</span>
    <span>3</span>
</div>
<hr />
<div class="box2">
    <span>1</span>
    <span>2</span>
    <span>3</span>
</div>
</body>
</html>

在这里插入图片描述

再来一个神奇是案例:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <!--    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">-->
    <title>测试文档</title>
    <style>
        [class^="box"]{

            width: 800px;
            height: 600px;
            background-color: #4a90e2;
        }
        .box1{
            display: flex;

        }
        .box1 span:nth-child(1){
            width: 200px;
            height: 200px;
            background-color: #55a532;
        }
        .box1 span:nth-child(2){
            flex: 1;
            height: 200px;
            background-color: #f86262;
        }
        .box1 span:nth-child(3){
            width: 200px;
            height: 200px;
            background-color: #55a532;
        }

    </style>
</head>
<body>
<div class="box1">
    <span>1</span>
    <span>2</span>
    <span>3</span>
</div>

</body>
</html>

在这里插入图片描述

这个份数不一定非得是1:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <!--    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">-->
    <title>测试文档</title>
    <style>
        [class^="box"]{

            width: 800px;
            height: 600px;
            background-color: #4a90e2;
        }
        .box1{
            display: flex;

        }
        .box1 span:nth-child(1){
            flex: 1;
            height: 200px;
            background-color: #55a532;
        }
        .box1 span:nth-child(2){
            flex: 1;
            height: 200px;
            background-color: #f86262;
        }
        .box1 span:nth-child(3){
            flex: 3;
            height: 200px;
            background-color: #55a532;
        }

    </style>
</head>
<body>
<div class="box1">
    <span>1</span>
    <span>2</span>
    <span>3</span>
</div>

</body>
</html>

在这里插入图片描述

align-self

这个属性是控制子项目自己在侧轴的排列方式。

在这里插入图片描述

align-self控制子元素在侧轴上的排列方式,允许单个子元素与其它不应有对齐方式,可以覆盖align-items属性。默认是auto,表示继承父类的align-items属性,如果没有父元素,则等同于stretch。

里面属性意义就不再重复,和前面的意思一样,就演示要给。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <!--    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">-->
    <title>测试文档</title>
    <style>
        [class^="box"]{

            width: 800px;
            height: 600px;
            background-color: #4a90e2;
        }
        .box1{
            display: flex;

        }
        span{
            /* 可以看出这个宽度就意义了*/
            width: 200px;
            height: 200px;
            background-color: #55a532;
            margin-left: 5px;
            flex: 1;


        }
        span:nth-child(3){
            align-self: flex-end;
        }
    </style>
</head>
<body>
<div class="box1">
    <span>1</span>
    <span>2</span>
    <span>3</span>
</div>

</body>
</html>

在这里插入图片描述

order属性定义项目排列顺序

这个是定位中的z-index不一样的地方是,z-index的数值越大,显示谁,而order却是数值越小越是在前面。

在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <!--    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">-->
    <title>测试文档</title>
    <style>
        [class^="box"]{

            width: 800px;
            height: 600px;
            background-color: #4a90e2;
        }
        .box1{
            display: flex;

        }
        span{
            /* 可以看出这个宽度就意义了*/
            width: 200px;
            height: 200px;
            background-color: #55a532;
            margin-left: 5px;
            flex: 1;


        }
        span:nth-child(3){
            order: -1;
        }
    </style>
</head>
<body>
<div class="box1">
    <span>1</span>
    <span>2</span>
    <span>3</span>
</div>

</body>
</html>

在这里插入图片描述


http://www.niftyadmin.cn/n/619605.html

相关文章

CSS基础:flex布局子元素被撑大(文本省略号)

文本撑大子盒子 在使用flex布局中&#xff0c;会有下面这样一个问题。 这种问题不但会让盒子撑大&#xff0c;而且还有自己在再使用超过文本长度使用省略号的时候&#xff0c;也会再拉动窗口的时候&#xff0c;变的没有效果。 如下&#xff1a; <!DOCTYPE html> <…

CSS基础: rem和媒体查询

rem单位 em 单位 首先说一个单位&#xff1a;em em 值的大小是动态的。当定义或继承font-size属性时&#xff0c;1em等于该元素的字体大小。如果你在网页中任何地方都没有设置文字大小的话&#xff0c;那它将等于浏览器默认文字大小&#xff0c;通常是16px。所以通常1em 16…

CSS基础:Less的使用以及注意项

前言 CSS在开发的时候会发现一件事&#xff0c;就是无法使用方法以及加入逻辑运算&#xff0c;这个时候就有大神发明了一门兼容CSS的扩展语言Less&#xff08;Leaner Style Sheet&#xff09;。 简单的说就是安装less的要求&#xff0c;可以使用一些编程语言中的变量&#xf…

CSS基础:vw和vh是什么

前面聊两个相对的单位em和rem&#xff0c;不过随着时代的发展&#xff0c;em和rem对于有些移动端的内容显示虽然可以达到效果&#xff0c;所以又衍生了两个单位vw和vh。 两个也是相对单位不过其相对的是视口&#xff08;非body标签定义的宽度&#xff09;的&#xff0c; vw&a…

JavaScript基础:Math,Date,String常用方法。

JavaScript中对象主要有3种&#xff1a;自定义对象&#xff0c;内置对象&#xff0c;浏览器对象。 自定义对象&#xff1a;就是自己定义的对象。内置对象&#xff1a;就是JavaScript自带的一些对象&#xff0c;比如前面聊的数组等&#xff0c;说白了就是自己可以直接用的对象以…

JavaScript基础:DOM操作之获得元素方法

现在聊一下JavaScript中的DOM操作&#xff0c;简单是说就是通过js操作页面的行为。本篇主要聊如何获得元素以及一些定义。 简介 DOM ( Document Object Model) : 文档对象模型&#xff0c;是W3C组织推荐处理可扩展语言&#xff08;HTML或者XML&#xff09;的标准编程接口。 …

JavaScript基础: DOM操作中常用事件

上一篇聊了如何同JavaScript获得页面元素&#xff0c;而获得页面元素的的目的就是操作这个元素的一行为&#xff0c;而这个行为是通过某个条件进行触发的。而这个一系列在JavaScript中称之为事件。 由此可以看出事件分三个部分&#xff1a; 事件源头&#xff1a; 也就是要操作…