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>

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.mzph.cn/news/213149.shtml

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

相关文章

【EI会议征稿中】第六届下一代数据驱动网络国际学术会议(NGDN 2024)

第六届下一代数据驱动网络国际学术会议&#xff08;NGDN 2024&#xff09; The Sixth International Conference on Next Generation Data-driven Networks 基于前几届在英国埃克塞特 (ISPA 2020) 、中国沈阳 (TrustCom 2021) 和中国武汉 (IEEETrustCom-2022)成功举办的经验&a…

若依vue-新建目录及菜单

前面我们把标题和logo换成了自己系统的标题和logo了 接下来就是要建立自己需要的菜单和页面 新建目录解析 在拉下来的代码跑起来后 有一个系统菜单--菜单管理(如图) 在这个菜单的这个页面内有对应的操作功能 修改功能 这个功能可以修改写好了的菜单数据 例如:名称/排序/路由…

python:五种算法(DBO、WOA、GWO、PSO、GA)求解23个测试函数(python代码)

一、五种算法简介 1、蜣螂优化算法DBO 2、鲸鱼优化算法WOA 3、灰狼优化算法GWO 4、粒子群优化算法PSO 5、遗传算法GA 二、5种算法求解23个函数 &#xff08;1&#xff09;23个函数简介 参考文献&#xff1a; [1] Yao X, Liu Y, Lin G M. Evolutionary programming made…

【小白专用】php执行sql脚本 更新23.12.10

可以使用 PHP 的 mysqli 扩展来执行 SQL 脚本。具体步骤如下&#xff1a; 连接到数据库&#xff1b;打开 SQL 脚本文件并读取其中的 SQL 语句&#xff1b;逐条执行 SQL 语句&#xff1b;关闭 SQL 脚本文件&#xff1b;关闭数据库连接。 以下是通过 mysqli 执行 SQL 脚本的示例…

生产问题: 利用线程Thread预加载数据缓存,其它类全局变量获取缓存偶发加载不到

生产问题: 利用线程Thread预加载数据缓存偶发加载不到 先上代码 public class ThreadTest {//本地缓存Map<String, Object> map new HashMap<String, Object>();class ThreadA implements Runnable{Overridepublic void run() {System.out.println("Thread…

RT-Thread学习笔记(六):RT_Thread系统死机日志定位

RT_Thread系统死机日志定位 一、RT_Thread系统死机日志定位二、Cortex-M3 / M4架构知识2.1 Cortex-M3 / M4架构概述2.2 寄存器用途 三、排查步骤 一、RT_Thread系统死机日志定位 RT-Thread 系统发生hardfault死机时&#xff0c;系统默认会打印出一系列寄存器状态帮助用户定位死…

XML学习及应用

介绍XML语法及应用 1.XML基础知识1.1什么是XML语言1.2 XML 和 HTML 之间的差异1.3 XML 用途 2.XML语法2.1基础语法2.2XML元素2.3 XML属性2.4XML命名空间 3.XML验证3.1xml语法验证3.2自定义验证3.2.1 XML DTD3.2.2 XML Schema3.2.3PCDATA和CDATA区别3.2.4 参考 1.XML基础知识 1…

AWR1642 boost开发板支持的TI参考设计

打开radar_toolbox_1_30_00_05\source\ti\examples\examples_overview,通过输入“1642”查找AWR1642 BOOST支持的参考设计,通过筛选,支持AWR1642 BOOST的参考设计如下: 挑选出两个参考设计上手,一个是“nonos_oob_16xx",不带OS;另一个是”short range radar“,比较…

Sbatch, Salloc提交任务相关

salloc 申请计算节点&#xff0c;然后登录到申请到的计算节点上运行指令&#xff1b; salloc的参数与sbatch相同&#xff0c;该部分先介绍一个简单的使用案例&#xff1b;随后介绍一个GPU的使用案例&#xff1b;最后介绍一个跨节点使用案例&#xff1b; 首先是一个简单的例子&a…

Go开发运维:Go服务发布到K8S集群

目录 一、实验 1.Go服务发布到k8s集群 二、问题 1.如何从Harbor拉取镜像 一、实验 1.Go服务发布到k8s集群 &#xff08;1&#xff09;linux机器安装go(基于CentOS 7系统) yum install go -y &#xff08;2&#xff09;查看版本 go version &#xff08;3&#xff09;创…

【参天引擎】华为参天引擎内核架构专栏开始更新了,多主分布式数据库的特点,类oracle RAC国产数据开始出现了

cantian引擎的介绍 ​专栏内容&#xff1a; 参天引擎内核架构 本专栏一起来聊聊参天引擎内核架构&#xff0c;以及如何实现多机的数据库节点的多读多写&#xff0c;与传统主备&#xff0c;MPP的区别&#xff0c;技术难点的分析&#xff0c;数据元数据同步&#xff0c;多主节点的…

Python 中 4 个高效的技巧(建议收藏)

今天我想和大家分享 4 个省时的 Python 技巧&#xff0c;可以节省 10~20% 的 Python 执行时间。 反转列表 Python 中通常有两种反转列表的方法&#xff1a;切片或 reverse() 函数调用。这两种方法都可以反转列表&#xff0c;但需要注意的是内置函数 reverse() 会更改原始列表…

【数据结构】C语言结构体详解

目录 前言 一、结构体的定义 二、定义结构体变量 三、结构体变量的初始化 四、使用typedef声明新数据类型名 五、指向结构体变量的指针 总结 &#x1f308;嗨&#xff01;我是Filotimo__&#x1f308;。很高兴与大家相识&#xff0c;希望我的博客能对你有所帮助。 &#x1f4a1…

做题笔记:SQL Sever 方式做牛客SQL的题目--查询每天刷题通过数最多的前二名用户

----查询每天刷题通过数最多的前二名用户id和刷题数 现有牛客刷题表questions_pass_record&#xff0c;请查询每天刷题通过数最多的前二名用户id和刷题数&#xff0c;输出按照日期升序排序&#xff0c;查询返回结果名称和顺序为&#xff1a; date|user_id|pass_count 表单创建…

Spring JDBC和事务管理

Spring JDBC是Spring框架用来处理关系型数据库的模块&#xff0c;对JDBC的API进行了封装。 Spring JDBC的核心类为JdbcTemplate&#xff0c;提供数据CRUD方法 Spring JDBC使用步骤 Maven工程引入依赖spring-jdbc <dependency><groupId>org.springframework<…

对Spring源码的学习:Bean实例化流程

目录 SpringBean实例化流程 Spring的后处理器 Bean工厂后处理器 Bean后处理器 SpringBean实例化流程 Spring容器在进行初始化时&#xff0c;会将xml配置的<bean>的信息封装成一个BeanDefinition对象&#xff0c;所有的BeanDefinition存储到一个名为beanDefinitionMa…

Docker容器的可视化管理工具—DockerUI本地部署与远程访问

文章目录 前言1. 安装部署DockerUI2. 安装cpolar内网穿透3. 配置DockerUI公网访问地址4. 公网远程访问DockerUI5. 固定DockerUI公网地址 前言 DockerUI是一个docker容器镜像的可视化图形化管理工具。DockerUI可以用来轻松构建、管理和维护docker环境。它是完全开源且免费的。基…

2023 CCF中国软件大会(CCF ChinaSoft) “程序语义深度理解前沿进展”论坛成功召开...

2023年12月2日&#xff0c;2023年度CCF中国软件大会软件程序语义深度理解前沿进展论坛成功召开。 本次论坛由南京大学卜磊老师和国防科技大学陈振邦老师主持&#xff0c;计算机研究与发展期刊代表侯丽珊老师致辞&#xff0c;旨在反映程序语义理解及其应用相关研究前沿进展与实践…

Vue之模板语法

模板语法有两大类&#xff1a; 1.插值语法 2.指令语法 让我为大家介绍一下吧&#xff01; 一、插值语法 功能:用于解析标签体内容。 写法: {{xxx}}&#xff0c;xxx是js表达式&#xff0c;且可以直接读取到data中的所有属性。 举个例子&#xff1a; <!DOCTYPE html> &l…

探索未来新趋势:鸿蒙系统的崭新时代

探索未来新趋势&#xff1a;鸿蒙系统的崭新时代 随着科技的不断发展&#xff0c;操作系统作为计算机和移动设备的核心&#xff0c;扮演着至关重要的角色。近年来&#xff0c;一种备受瞩目的操作系统——鸿蒙系统&#xff08;HarmonyOS&#xff09;崭露头角&#xff0c;正引领着…