float,flex和grid布局

这篇具有很好参考价值的文章主要介绍了float,flex和grid布局。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

页面布局往往会影响着整体的结构与项目的样式,通常我们用的布局方式有三种:float,flex,grid

1.float或position布局

1.1概念

     首先对于一个页面来说,有浮动流,文档流,文本流这几种模式,而float布局则是脱离文档流而不脱离文本流,就是页面的元素会无视这个浮动的元素,正常布局的正常布局,只是浮动的元素会在正常的元素上方就像浮起来了。
浮动会激活元素的BFC(块级格式化上下文),使元素脱离文档流,它是一个独立的渲染区域,有自己的渲染规则,与这个区域外部的规则毫无关系

1.2实现

     通过position或float来实现布局,首先使用float让其浮动,脱离文档流,就好比像有两层空间,一般写的元素的在一层,浮动的则是在另一层。position如果是绝对定位(absolute),也会浮动起来,就需要设置left,right,top,bottom这四个属性去移动

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title>Demo</title>
        <style>
            .float{
               float: left;//靠左浮动
               width: 100px;
               height: 100px;
               background-color: aqua;
            }
            .item{
                background-color: bisque;
                width: 100%;
                height: 500px;
            }
        </style>                                             
    </head>
    <body>
        <div class="container">
            <div class="float">float</div>
            <div class="item"></div>
        </div>
    </body>
</html>

效果:
float,flex和grid布局
原本两个盒子应该是这样的
float,flex和grid布局

1.3优缺点

     缺点:步骤繁琐,使用困难,同时浮动需要清除,不然会影响样式。同时对于布局构思能力要求很高,现在基本不会用,除非Ie浏览器。
     优点:包容性强大。

2.flex布局

2.1概念:

     flex就是弹性盒子布局,Flex布局是CSS3新增的一种CSS布局模式,它能够让元素更加简便的布局,并支持响应式布局。它通过“容器”和“项目”两个元素进行布局,允许容器中的项目能够灵活地伸缩和排列,以适应不同的屏幕尺寸或设备。一般来说父容器,子项目,它的所有子元素自动成为容器成员,称为Flex项目(flex item),简称”项目”。

1.2实现

     flex布局是一维布局,所以需要设置横和竖的布局方式,用flex-direction去决定方向。

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title>Demo</title>
        <style>
            .container{
               width: 100%;
               height: 100px;
                background-color: aqua;
                //一般设置这三个属性就行了
                display: flex;//定义为flex布局
                flex-direction: row;//子元素(项目)排列方式,有row--正方向行,row-reverse--反方向行,column--正方向列,
                //column-reverse--反方向列
                justify-content: space-around;//有这些值: flex-start | flex-end | center |
                // space-between | space-around;
            }
            .item{
                width: 100px;
                height: 100px;
                border: black solid 2px;
                text-align: center;
            }
        </style>                                             
    </head>
    <body>
        <div class="container">
            <div class="item" style="background-color: yellow;">yellow</div>
            <div class="item" style="background-color: blue;">blue</div>
            <div class="item" style="background-color: pink;">pink</div>
        </div>
    </body>
</html>

效果:
float,flex和grid布局
原本的:
float,flex和grid布局

1.3相关属性

     flex布局有些常用的属性:

  • flex-direction:定义主轴的方向(row、row-reverse、column、column-reverse);
  • justify-content:定义元素在主轴上的对齐方式(flex-start、flex-end、center、space-between、space-around);
  • align-items:定义元素在交叉轴上的对齐方式(flex-start、flex-end、center、baseline、stretch);
  • flex-wrap:定义元素的换行方式(nowrap、wrap、wrap-reverse);
  • align-content:定义多行元素在交叉轴上的对齐方式(flex-start、flex-end、center、space-between、space-around、- >stretch);
  • flex-grow:定义元素的放大比例;
  • flex-shrink:定义元素的缩小比例;
  • flex-basis:定义元素在分配多余空间之前的基准大小;
1.4优缺点

     优点:

  • 简单易用:Flex布局用起来比传统的布局方式更加方便和快捷。

  • 布局灵活:能够实现各种方向和大小的布局,确保页面在不同设备和窗口大小下都能正常显示。

  • 支持对齐和分布:Flex布局支持多种对齐和分布方式,可用于实现水平居中、垂直居中、顶部对齐、底部对齐等。

  • 自适应:Flex布局可以根据不同的设备和屏幕大小来适应布局,使页面在各种不同的设备上都能正常显示。

  • 支持动画和过渡效果:Flex布局支持动画和过渡效果,可用于实现各种动态效果。

     缺点:

  • 兼容性问题:由于Flex布局是CSS3的新特性,旧版本的浏览器可能不支持。

  • 可读性问题:由于Flex布局使用的是大量的flex属性和值,使得代码相对较长,可读性较差

3.grid布局

3.1概念:

     Grid布局是CSS中一种基于网格的布局方式,它将一个页面分成了一系列的行和列,并将网格中的内容放置在这些行和列中,可以实现更加灵活和高效的页面布局。Grid 布局则是将容器划分成“行"和“列”,产生单元格,然后指定"项目所在”的单元格,功能比flex强大,是一种二维的布局方式。

3.2实现:

     和flex布局差不多,通过display:grid先实现,在根据grid-template-columns或者 grid-template-rows去设置行与列。

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title>Parallax Scrolling Demo</title>
        <style>
            .container{
               width: 100%;
               height: 100px;
               display: grid;
               grid-template-rows:100px 100px ;//设置每一行的宽度,其中每个数字代表这一行
               grid-template-columns: 100px 100px;//设置每一列的宽度,其中每个数字代表这一列
            }
            .item{
                border: black solid 2px;
                text-align: center;
            }
        </style>                                             
    </head>
    <body>
        <div class="container">
            <div class="item" style="background-color: yellow;">yellow</div>
            <div class="item" style="background-color: blue;">blue</div>
            <div class="item" style="background-color: pink;">pink</div>
            <div class="item" style="background-color: pink;">pink</div>
        </div>
    </body>
</html>

效果:
float,flex和grid布局
原本的效果和flex布局一样

3.3属性:

     grid布局的属性很多,也很复杂

  • grid-template-columns/grid-template-rows:定义网格的列和行的数量和大小。
  • grid-template-areas:定义网格模板中的区域名称。
  • grid-template:以上两者的缩写形式。
  • grid-column-gap/grid-row-gap/grid-gap:定义列、行、以及列与行之间的间距。
  • grid-auto-columns/grid-auto-rows:定义没有列、行指定的网格单元格的大小。
  • grid-auto-flow:控制自动布局算法在什么方向上填充网格。
3.4 优缺点

优点:

  • 精确的控制布局:可以通过列和行来精确控制每个子元素在布局中的位置和大小。
  • 灵活性:可以使用媒体查询来针对不同的屏幕尺寸或方向添加或移除列或行。
  • 可维护性:可以很容易地修改布局而不必担心其他元素的影响。
  • 易于理解:与传统的 float、position 和 display 属性相比,Grid 布局的代码更容易理解和维护。

缺点:文章来源地址https://www.toymoban.com/news/detail-421957.html

  • 兼容性:虽然 Grid 布局已成为现代浏览器的标准,但在旧版浏览器中并不支持。开发者需要使用其他方式来提供备用方案。
  • 学习成本高:与传统的 float、position 和 display 属性相比,学习和理解 Grid 布局可能需要更长的时间和更高的学习成本。
  • 可读性差:因为 Grid 布局使用了许多新的术语(如 grid-template-columns 和 grid-template-rows),因此初学者可能需要花更多的时间来理解和阅读代码

到了这里,关于float,flex和grid布局的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 使用flex弹性布局来为微信小程序写自适应页面

    我们知道,写习惯了前端的人,一般切图后布局页面的话,上手最习惯的是基于盒子模型的浮动布局,依赖 display 属性 + position属性 + float属性,但是浮动布局有一些致命的小问题,比如垂直居中比较费劲,比如著名的float坍塌问题,另外有些极端情况下,还得使用模型+clear

    2024年02月09日
    浏览(50)
  • CSS水平垂直居中(最常见的三种方案flex、grid、absolute)

    本文简单介绍一下现代 CSS 中最常见的三种水平垂直居中方案。 html: css: 方案1:父元素设置 flex 布局,并设置主轴以及交叉轴的对齐方式: 方案2:父元素设置 flex 布局,子元素设置 margin: auto : 父元素设置 grid 布局,以及 place-items: center 。 place-items  是  align-items  和 

    2024年01月16日
    浏览(47)
  • float浮动布局大战position定位布局

    1.普通文档流布局:我们得网页内容从上往下,从左往右进行的布局,其中块元素独占一行(我们可以使用margin,padding,display,line-height去进行布局) 2.浮动布局:浮动可以使用一个元素脱离自己原本的位置,并在父级元素的内容区中向左或向右移动,直到碰到父级元素内容

    2024年02月09日
    浏览(41)
  • css3-grid:grid 布局 / 基础使用

    一、理解 grid   二、理解 css grid 布局 CSS Grid布局是一个二维的布局系统,它允许我们通过定义网格和网格中每个元素的位置和尺寸来进行页面布局。CSS Grid是一个非常强大的布局系统,它不仅可以用于构建网格布局,还可以用于定位元素,并且可以很好地处理复杂的布局。

    2024年02月12日
    浏览(42)
  • 【CSS】flex布局用法解析,快速上手flex布局,flex:1是什么意思?肯定看的懂好吧?

    flex 是 flexible box 的缩写,意为\\\"弹性布局\\\",用来为盒状模型提供最大的灵活性。 任何一个容器都可以指定为 flex 布局。 采用 flex 布局的元素,称为 flex 容器(flex container),简称\\\"容器\\\"。 flex-direction 属性决定主轴的方向(也就是元素的排列方向),与主轴垂直的轴是交叉轴。

    2024年02月03日
    浏览(52)
  • 全面了解 Grid 布局

    grid 布局简介 Grid 布局是一种用于网页布局的 CSS 技术,它允许开发者定义一个元素内部的行和列,并在这些网格中放置子元素,是一个强大的布局方式。 容器属性 Grid 布局需要在父容器上设置 display 属性为 grid 或 inline-grid,以表明它们包含网格项。 行列定义 使用 grid-templ

    2024年02月01日
    浏览(36)
  • CSS Grid布局

    网格布局(Grid)将王爷分成一个个网格,可以任意组合不同的网格,做出各种各样的布局。Grid布局与Flex不具有一定的相似性,都可以指定容器内部多个项目的位置,但是他们存在重大的区别。flex布局时轴线布局,只能指定项目针对轴线的位置,可以看作是一维布局;grid布

    2024年02月15日
    浏览(52)
  • 43.CSS grid布局

    本节我们学习的初始代码如下: 注:如上,同行情况下,一个元素有高度的话,同行元素会被拉伸,这是默认行为 注:(3)没有被拉伸是因为它有固定高度

    2023年04月18日
    浏览(49)
  • Grid 拖拽布局实现

    最近有个需求需要实现自定义首页布局,需要将屏幕按照 6 列 4 行进行等分成多个格子,然后将组件可拖拽对应格子进行渲染展示。 示例 对比一些已有的插件,发现想要实现产品的交互效果,没有现成可用的。本身功能并不是太过复杂,于是决定自己基于 vue 手撸一个简易的

    2024年02月05日
    浏览(38)
  • CSS-grid布局

    网格布局也叫grid布局,平常写样式的时候基本上都是用的flex布局。 像以下布局,用flex布局就可能会有有点麻烦,这时候用grid布局就方便的多了。 或者是照片墙 grid布局就是将容器划分为行和列,产生单元格,然后在指定的单元格,可以看作是二维布局,我们一直经常用的

    2024年02月13日
    浏览(56)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包