css网格布局简单介绍

        前端网格布局是一种用于在网页上创建复杂网格系统的布局技术。它允许开发者通过简单的语法来定义和控制元素的排列方式,使得页面布局更加灵活和可预测。在CSS中,网格布局可以通过`display: grid`属性来实现。


         特点
        1. **灵活性**:网格布局可以轻松地创建复杂的网格系统,无论是等宽网格还是不等宽网格。
        2. **响应性**:网格布局能够很好地适应不同屏幕尺寸,因为它们是基于比例的。
        3. **可预测性**:网格布局的布局规则是固定的,这使得设计者和开发者能够更容易地预测和控制元素的布局。
        4. **易用性**:网格布局的语法简单,易于理解和使用。
         和Flex布局的不同之处
        1. **设计理念**:
   - **Flex布局**:主要用于一维布局,即项目的排列方向为水平或垂直。它主要用于对容器内的子元素进行对齐和分配空间。
   - **网格布局**:用于二维布局,可以控制元素在水平和垂直方向上的排列。
        2. **容器和项目**:
   - **Flex布局**:容器属性`display: flex`或`display: inline-flex`;项目属性`display: flex`。
   - **网格布局**:容器属性`display: grid`;项目属性`display: grid`或`display: inline-grid`。
        3. **子元素对齐**:
   - **Flex布局**:子元素可以通过`justify-content`和`align-items`属性进行对齐。
   - **网格布局**:子元素可以通过`justify-self`、`align-self`、`grid-column-start`、`grid-column-end`、`grid-row-start`和`grid-row-end`属性进行对齐和定位。
        4. **行和列**:
   - **Flex布局**:没有专门的行和列属性,主要是通过`flex-direction`来控制主轴的方向。
   - **网格布局**:有专门的行和列属性,如`grid-template-columns`和`grid-template-rows`,允许定义行和列的大小和间隔。
        例子和代码解释


        下面是一个简单的网格布局例子,以及代码解释。


<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Grid Layout Example</title>
<style>.container {display: grid;grid-template-columns: 1fr 2fr 1fr;grid-gap: 10px;}.item {background-color: lightblue;padding: 20px;text-align: center;}.item-1 {grid-column-start: 2;grid-column-end: 3;}
</style>
</head>
<body>
<div class="container"><div class="item item-1">1</div><div class="item">2</div><div class="item">3</div>
</div>
</body>
</html>

        在这个例子中,.container类定义了一个网格容器,它有三个列,分别由grid-template-columns属性指定。.item类定义了网格中的项目,它们默认会填充整个网格容器。grid-template-columns: 1fr 2fr 1fr;:这定义了网格容器的列,其中1fr代表一列,2fr代表两列,1fr代表一列。
grid-gap: 10px;:这定义了网格容器中列与列之间的间距。.item-1类通过grid-column-start和grid-column-end属性定义了项目的位置,它占据了从第二列开始到第三列结束的位置。
        在这个例子中,网格布局简单地创建了一个三列的布局,其中中间列占据了两列的空间。网格布局的灵活性体现在你可以轻松地调整列的大小,而无需修改项目的代码。
        总结
        前端网格布局是一种强大的布局技术,它允许开发者创建复杂的网格系统,使得页面布局更加灵活和可预测。与Flex布局相比,网格布局提供了更全面的控制,尤其是在创建复杂的多列布局时。网格布局的行和列属性使得布局设计更加直观,而Flex布局则更适合于单列的灵活布局。
        通过这个例子来展示网格布局的基本概念和语法。然后,还有 网格布局的其他高级特性,例如:
- `grid-template-areas`:允许开发者定义网格区域,并指定哪些项目应该放置在这些区域。
- `grid-auto-columns`和`grid-auto-rows`:自动创建未明确定义的行和列。
- `place-items`:一个简写属性,用于同时设置`align-items`和`justify-items`。
- `grid-template-rows`和`grid-template-columns`:用于定义网格线的名称,这在需要更复杂的布局时非常有用。
 

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

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

相关文章

微信小程序开发系列(十一)·小程序页面的跳转设置以及参数传递

目录 1. 跳转到商品列表 1.1 url: 当前小程序内的跳转链接 1.2 navigate&#xff1a;保留当前页面&#xff0c;跳转到应用内的某个页面。但是不能跳到 tabbar 页面 1.3 redirect&#xff1a; 关闭当前页面&#xff0c;跳转到应用内的某个页面。但不能跳转到 tabbar 页面…

在 Flutter 中使用 flutter_gen 简化图像资产管理

你是否厌倦了在 Flutter 项目中手动管理图像资产的繁琐任务&#xff1f; 告别手工输入资源路径的痛苦&#xff0c;欢迎使用“Flutter Gen”高效资源管理的时代。在本文中&#xff0c;我将带您从手动处理图像资源的挫折到动态生成它们的便利。 选择1&#xff1a;痛苦手动添加–…

Jenkins如何做到parameter页面里2个参数的联动

在Jenkins中&#xff0c;参数化构建是一种非常有用的功能&#xff0c;它可以让用户在构建过程中输入参数&#xff0c;从而实现更灵活的构建流程。有时候&#xff0c;我们希望两个参数之间能够实现联动&#xff0c;即一个参数的取值会影响另一个参数的取值。要实现这样的功能&am…

ChatGPT编程省钱、方便小示例——实现PDF转成PNG文件

ChatGPT编程省钱、方便小示例——实现PDF转成PNG文件 今天登录一个网站发现一个pdf文件很漂亮&#xff0c;于是想下载下来转成png图片。 于是用wps软件打开&#xff0c;然后进行转换。。。。。。 果然天下没有免费的午餐。既然AI时代已经到来&#xff0c;那就交给无所不能的AI…

DataGrip 连接 Centos MySql失败

首先检查Mysql是否运行&#xff1a; systemctl status mysqld &#xff0c; 如果显示没有启动则需要启动mysql 检查防火墙是否打开&#xff0c;是否打开3306的端口 sudo firewall-cmd --list-all 如果下面3306没有打开则打开3306端口 publictarget: defaulticmp-block-inver…

2195. 深海机器人问题(网络流,费用流,上下界可行流,网格图模型)

活动 - AcWing 深海资源考察探险队的潜艇将到达深海的海底进行科学考察。 潜艇内有多个深海机器人。 潜艇到达深海海底后&#xff0c;深海机器人将离开潜艇向预定目标移动。 深海机器人在移动中还必须沿途采集海底生物标本。 沿途生物标本由最先遇到它的深海机器人完成采…

【自动驾驶技术系列丛书学习】1.《自动驾驶技术概论》学习笔记

《自动驾驶技术概论》学习笔记 致谢&#xff1a;作者&#xff1a;王建、徐国艳、陈竞凯、冯宗宝 -------------------------------------------------------------------------------------------------------- 笔记目录 《自动驾驶技术概论》学习笔记 1.汽车发展史 2.国…

Docker常用基础指令

目录 1 前言 2 常用指令 2.1 获取帮助 2.2 拉取镜像到本地 2.3 对本地镜像进行打包 2.4 对本地镜像的删除 2.5 通过tar包加载本地镜像 2.6 查看所有镜像 2.7 创建新的容器 2.8 查看容器 2.9 停止容器运行 2.10 运行容器 2.11 删除容器 2.12 查看容器日志 2.13 进…

如何使用 ArcGIS Pro 统计四川省各市道路长度

在某些时候&#xff0c;我们需要进行分区统计&#xff0c;如果挨个裁剪数据再统计&#xff0c;不仅步骤繁琐、耗时&#xff0c;还会产生一些多余的数据&#xff0c;这里教大家如何在不裁剪数据的情况下统计四川各市的道路长度&#xff0c;希望能对你有所帮助。 数据来源 教程…

【MySQL】视图 -- 详解

视图 是一个虚拟表&#xff0c;其内容由查询定义。同真实的表一样&#xff0c;视图包含一系列带有名称的列和行数据。视图的数据变化会影响到基表&#xff0c;基表的数据变化也会影响到视图。 一、基本使用 1、创建视图 create view 视图名 as select 语句; 好处&#xff1a;…

UEFI Secure Boot

一、前言 在计算机世界&#xff0c;安全是一个永恒的话题。微软的Windows的安全性一直深受诟病&#xff0c;但随着操作系统层面的漏洞逐渐减少&#xff0c;黑客们盯上了BIOS固件。那如何保证从开机到进入操作系统这个过程中的安全呢&#xff1f;下图是Intel CPU的整个UEFI安全启…

洞察未来5-10年数字化转型的革命性趋势

“十四五”规划和2035年远景目标纲要提出了加快数字化发展&#xff0c;建设数字中国的目标&#xff0c; 这意味着数字化转型将成为推动生产方式、生活方式和治理方式变革的关键力量。 加快数字化发展 建设数字中国 ⭐ 打造数字经济新优势 ⭐ 加快数字社会建设步伐 ⭐ 提高数字…

软考62-上午题-【面向对象技术】-面向对象的基本概念1

一、封装 1-1、封装的定义 一个对象把属性和行为封装为一个整体。是一种信息隐蔽技术。 封装就是将类的某些信息隐藏在类内部&#xff0c;不允许外部程序直接访问&#xff0c;而是通过该类提供的方法&#xff08;getter和setter&#xff09;来实现对隐藏信息的操作和访问。 封…

Docker发布镜像(DockerHub,阿里云)

目录 1、发布到DockerHub上 2、发布到阿里云镜像服务上 小结 1、发布到DockerHub上 1.地址https://hub.docker.com/注册自己的账号 2.确定这个账号可以登录 3.在服务器上提交自己的镜像 [rootwq test]# docker login --helpUsage: docker login [OPTIONS] [SERVER]Log in…

数据存储格式

数据存储格式是指数据在存储介质中表示和组织的方式&#xff0c;以便于读取、写入和管理。 csv&#xff08;逗号分隔值&#xff09; CSV&#xff08;Comma-Separated Values&#xff0c;逗号分隔值&#xff09;是一种常见的数据存储格式&#xff0c;它以纯文本形式存储表格数…

uniapp实现---类似购物车全选

目录 一、实现思路 二、实现步骤 ①view部分展示 ②JavaScript 内容 ③css中样式展示 三、效果展示 四、小结 注意事项 一、实现思路 点击商家复选框&#xff0c;可选中当前商家下的所有商品。点击全选&#xff0c;选中全部商家的商品 添加单个多选框&#xff0c;在将多选…

在XCode中使用SwiftGen管理你的图片、配色、多语言文件等

SwiftGen是一个工具&#xff0c;可以为您的项目资源&#xff08;如图像、本地化字符串等&#xff09;自动生成Swift代码&#xff0c;然后你就可以像使用一个Class类一样访问你的资源了。 而且添加或更新资源后&#xff0c;SwiftGen也会自动更新用于访问资源的Class类。对于管理…

H3C 路由过滤路由引入实验

H3C 路由过滤&路由引入实验 实验拓扑 ​​ 实验需求 按照图示配置 IP 地址&#xff0c;R1&#xff0c;R3&#xff0c;R4 上使用 loopback 口模拟业务网段R1 和 R2 运行 RIPv2&#xff0c;R2&#xff0c;R3 和 R4 运行 OSPF&#xff0c;各自协议内部互通在 RIP 和 OSPF …

computed和methods的区别

computed和methods在Vue.js中都是用于处理数据和逻辑的方法&#xff0c;但它们之间存在一些重要的区别。 缓存机制&#xff1a;computed属性是基于它们的依赖进行缓存的。只有当它的相关依赖发生改变时才会重新计算。这意味着只要计算属性依赖的响应式属性没有发生变化&#x…

Android9-W517-使用NotificationListenerService监听通知

目录 一、前言 二、前提 三、方案 方案一 方案二 方案三 方案四 方案五 方案六 方案七 四、关于NotificationListenerService类头注释 五、结论 一、前言 NotificationListenerService可以让应用监听所有通知&#xff0c;但是无法获得监听通知的权限&#xff0c;如…