float,flex和grid布局

news2024/9/20 1:27:50

页面布局往往会影响着整体的结构与项目的样式,通常我们用的布局方式有三种: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>

效果:
在这里插入图片描述
原本两个盒子应该是这样的
在这里插入图片描述

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>

效果:
在这里插入图片描述
原本的:
在这里插入图片描述

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>

效果:
在这里插入图片描述
原本的效果和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 布局的代码更容易理解和维护。

缺点:

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/449177.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

接口文档设计的12个注意点

前言 我们做后端开发的,经常需要定义接口文档。 最近在做接口文档评审的时候&#xff0c;发现一个小伙伴定义的出参是个枚举值&#xff0c;但是接口文档没有给出对应具体的枚举值。其实&#xff0c;如何写好接口文档&#xff0c;真的很重要。今天给你带来接口文档设计的12个注…

Camera Tuning - MTK pipeline

MTK ISP Pipeline 模块介绍&#xff1a; BPC&#xff1a;坏点矫正 OBC&#xff1a;OB矫正 FUS&#xff1a;此节点处理后&#xff0c;支持视频、预览HDR Digital Gain&#xff1a; 1、LSC&#xff1a;shading矫正 2、WB&#xff1a;白平衡矫正&#xff08;此步处理后&#xff0…

数字设计笔试Verilog手撕代码 - 累加器

前言 本系列整理关于数字设计的笔试或面试的设计问题&#xff0c;手撕代码继续撕&#xff0c;今天撕一个百度昆仑笔试题的累加器设计。 设计需求 题目来源&#xff1a; 【数字IC/FPGA】百度昆仑芯手撕代码–累加器 已知一个加法器IP&#xff0c;其功能是计算两个数的和&am…

虚幻图文笔记:如何清理Character Creator角色的垃圾数据

书接上文《虚幻图文笔记&#xff1a;Character Creator 4角色通过AutoSetup For Unreal Engine插件导入UE5.1的过程笔记》 在一个项目中我按照上文的步骤导入UE5&#xff0c;但是产生了一些莫名其妙的文件&#xff0c;下面还原一下发现和解决问题的过程。 1. 使用Character Cr…

【C++入门必备知识】

【C入门必备知识】 ①.【命名空间】1.命名空间定义Ⅰ.正常定义命名空间Ⅱ.嵌套定义命名空间Ⅲ.合并命名空间 2.命名空间的使用Ⅰ.命名空间名称及域作用限定符Ⅱ.using成员引入Ⅲ.using namespace名称全部引入 3.注意事项Ⅰ.概念1.全缺省参数2.半缺省参数3.使用规则4.应用场景再…

Baumer工业相机堡盟工业相机如何通过BGAPISDK的软触发实现两相机的同步采集(C#)

Baumer工业相机堡盟工业相机如何通过BGAPISDK的软触发实现两相机的同步采集&#xff08;C#&#xff09; Baumer工业相机Baumer工业相机的高速同步采集的技术背景Baumer工业相机通过BGAPI SDK在回调函数里同步保存图像工业相机在回调函数BufferEvent保存工业相机使用软触发进行同…

#Chrome扩展程序开发教程--04:权限申请

#Chrome扩展程序开发教程--04&#xff1a;权限申请 引言1、基本介绍2、权限相关属性2.1、permissions2.2、optional_permissions2.3、host_permissions2.4、optional_host_permissions 3、申请权限4、检查权限5、移除权限 引言 本系列博客旨在带来最新的Chrome扩展程序开发入门…

C语言函数大全-- m 开头的函数

C语言函数大全 本篇介绍C语言函数大全-- m 开头的函数 1. malloc 1.1 函数说明 函数声明函数功能void *malloc(size_t size);用于动态分配内存 参数&#xff1a; size &#xff1a; 需要分配的内存大小&#xff08;以字节为单位&#xff09; 返回值&#xff1a; 如果分配成…

【Spring】三大依赖注入(@Autowired,Setter,构造方法)

目录 一、属性注入&#xff08;Autowired&#xff09; 1.1 优点分析 1.2 缺点分析 1.2.1 无法实现final修饰的变量注入。 1.2.2 兼容性不好 1.2.3 &#xff08;可能违背&#xff09;设计原则问题 1.2.4 代码举例&#xff1a; 1.2.5 出现循环依赖该怎么办&#xff1f; 二…

自然语言模型的哲学小谈

近期&#xff0c;以chatGPT为代表的大语言模型表现非常惊艳。“In Context Learning”、“Instruct”1&#xff0c;以及推理能力&#xff0c;很难不让我们期待未来人工智能的发展&#xff0c;同时冷静思考一下为什么自然语言模型能够取得巨大进步。 文章目录 1 放空大脑从0开始…

Ngiinx反向代理和负载均衡

系列文章目录 目录 系列文章目录一、Nginx的反向代理1.代理含义2.反向代理配置模块 二、1.动静分离2.负载均衡实验 总结 一、Nginx的反向代理 1.代理含义 正向代理 正向代理&#xff0c;指的是通过代理服务器 代理浏览器/客户端去重定向请求访问到目标服务器 的一种代理服务…

ARP协议详解

ARP协议详解 文章目录 ARP协议详解ARP协议介绍ARP抓包ARP包解析 ARP协议介绍 ARP&#xff08;Address Resolution Protocol&#xff09;是一种用于将网络层地址&#xff08;如IP地址&#xff09;转换为数据链路层地址&#xff08;如MAC地址&#xff09;的协议&#xff0c;当一…

软件测试概念篇(下)|开发模型与测试模型

作者&#xff1a;爱塔居 专栏&#xff1a;软件测试 作者简介&#xff1a;大三学生&#xff0c;希望同大家一起进步&#xff01; 文章简介&#xff1a;主要介绍软件生命周期、瀑布模型和螺旋模型两个开发模型&#xff0c;V模型和W模型两个测试模型 文章目录 目录 文章目录 一、软…

【Go】五、网络编程

文章目录 网络编程1、互联网协议介绍2、Socket编程2.1、socket图解2.2、TCP编程2.3、UDP编程2.4、粘包&#xff08;❌没有详细看代码&#xff0c;但是大概知道怎么实现&#xff09; 3、Http编程4、WebSocket编程 网络编程 1、互联网协议介绍 2、Socket编程 2.1、socket图解 1…

这家工作室为网飞、亚马逊、迪士尼都制作过特效

过去的十年里&#xff0c;CGEV工作室通过为电影、电视剧以及Netflix、Amazon、Disney等平台制作大量内容&#xff0c;建立了坚不可摧的声誉。我们采访了CGEV团队&#xff0c;了解他们如何在每一个环节都依赖于ftrack Studio。 CGEV全称Compagnie Gnrale des Effets Visuels&…

C++缺省参数

目录 什么是缺省参数缺省参数分类全缺省参数半缺省参数 缺省参数函数的声明缺省参数的使用 什么是缺省参数 缺省参数是声明或定义函数时,为函数的参数指定一个缺省值。 在调用该函数时&#xff0c;如果没有指定实参&#xff0c;那么形参就会采用缺省值&#xff0c;如果指定了实…

【C语言】基础语法5:数组和指针

上一篇&#xff1a;函数和递归 下一篇&#xff1a;字符串和字符处理 ❤️‍&#x1f525;前情提要❤️‍&#x1f525;   欢迎来到C语言基本语法教程   在本专栏结束后会将所有内容整理成思维导图&#xff08;结束换链接&#xff09;并免费提供给大家学习&#xff0c;希望…

C#串口通信从入门到精通(4)——串口调试助手的使用

前言: 关于本文中使用到的串口助手工具,订阅专栏后,加入vip群,即可在群文件免费下载 1、认识串口助手 串口助手主要的功能有以下六个模块,功能介绍分别如下: 1.1 打开、关闭串口、清除接收区数据按钮区 这些按钮用于打开串口、关闭串口、清除接收数据区的数据 1.2 …

IIC协议——同步半双工串行通信方式

文章目录 前言一、简要介绍1、优点2、缺点 二、信号线和连接方式1、信号线2、连接方式2.1 单主设备&#xff0c;单从设备2.2 单主设备&#xff0c;多从设备2.3 多主设备&#xff0c;多从设备 三、数据传输格式1、数据传输过程 二、SPI配置1、传输模式2、地址位宽3、仲裁机制3.1…

【Linux】Linux基本指令(1)

一.前言 从这篇文章开始&#xff0c;博主就开启了Linux学习之路了&#xff0c;本篇文章也是博主的第一篇Linux的文章&#xff0c;今后也会持续不断更新的。 二.理解文件 1.文件 文件文件数据文件属性&#xff08;所以一个建好的文件就算没有数据&#xff0c;也占用存储空间&am…