iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > VUE >如何使用CSS Grid布局实现网格的流动
  • 548
分享到

如何使用CSS Grid布局实现网格的流动

2024-04-02 19:04:59 548人浏览 安东尼
摘要

这篇文章主要讲解了“如何使用CSS Grid布局实现网格的流动”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何使用CSS Grid布局实现网格的流动”吧!

这篇文章主要讲解了“如何使用CSS Grid布局实现网格的流动”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何使用CSS Grid布局实现网格的流动”吧!

html文档中有文档流,其实在CSS Grid Layout中有网格流。简单点理解就是,在一个被显式声明为网格的容器中,其所有子元素自动被认定为网格单元格,而这些网格单元格在没有被显式设置明确位置时,浏览器将会自动为这些网格单元格的位置进行计算,按照先后顺序从左向右,或从上到下排列。在这里把这种方式称之为网格的流动。

在具体介绍网格流动相关内容之前,我们先一起来回忆一个简单的效果。平时在WEB页面制作当中,经常会碰到产品列表展示页面,或者说相册展示页面的效果。如下图所示:

如何使用CSS Grid布局实现网格的流动

实现上图的效果,大家平时大多会采用floatdisplay:inline-block等方法实现。但这些方法或多或少存在一定的局限性。那么在CSS Grid Layout中,实现这样的布局相对而言会简单多。比如通过网格线,或者网格区域来明确指定各自的位置。不过这样一来,就存在一个潜在的问题:如果在不同的设备上浏览,每行展示的数量不一致时,需要在媒体查询中为每个网格重新指定位置,这变得更为复杂。也不是我们希望的效果。其实在网格布局中还有一种更方便的方法,就是采用网格流来实现。这也是我们今天要说的内容 。

网格的自动流

在CSS Grid Layout中,给元素显式的声明网格,如果没有显式的通过网格线或者网格区域明确指定网格的位置,那么浏览器将会对容器内子元素(网格单元格)进行自动布局。

来看一个简单的示例,假设容器.wrapper中有14个.box(A~O)。容器.wrapper显示的声明为网格,并且不对任何.box做显式的位置定位,这个时候浏览器会自动为.box进行自动布局。为了更好的看到效果,在这个示例中给偶数的.box设置了一个green背景色:

HTML

代码如下:


<div class="wrapper">
 <div class="box a">A</div>
 <div class="box b">B</div>
 <div class="box c">C</div>
 <div class="box d">D</div>
 <div class="box e">E</div>
 <div class="box f">F</div>
 <div class="box h">H</div>
 <div class="box i">I</div>
 <div class="box j">J</div>
 <div class="box k">K</div>
 <div class="box l">L</div>
 <div class="box m">M</div>
 <div class="box n">N</div>
 <div class="box o">O</div>
</div>

CSS

代码如下:


.box {
 background: orange;
 height: 100px;
 line-height: 100px;
 text-align: center;
 color: #fff;
 font-size: 3em;
}
.box:nth-child(even){
 background: green;
}
.wrapper {
 width: 500px;
 border: 1px solid orange;
 padding: 15px;
 margin: 20px auto;</p> <p>  display: grid;
 grid-template-columns: repeat(5, 100px);
 grid-template-rows: auto ;
}

效果如下:

如何使用CSS Grid布局实现网格的流动

在线案例

不过离文章所示效果还是略有差距,每个.box之间没有间距,我尝试着给.box设置margin值:

如何使用CSS Grid布局实现网格的流动

在线案例

从效果图中可以明显看出,盒模型解析已做出变化:

如何使用CSS Grid布局实现网格的流动

上图中可以得知,在CSS Grid Layout中盒模型大小计算变成:容器width = margin-left + margin-right + padding-left + padding-right + content width + border-left-width + border-right+width。比如我们这个示例中,.box设置width:100px,并且有一个margin-right:15px;那实际上.box的内容宽度仅只有85px。这样一来与文章开头示例相左,如果需要做到一致效果,还需对其做一定的变化。这个变化就是对容器.wrapper的宽度和grid-template-columns属性值:

代码如下:

<font face="Courier New">
<font face="Courier New">.wrapper {
 width: 560px;
 border: 1px solid orange;
 padding: 15px;
 margin: 20px auto;
 display: grid;
 grid-template-columns: repeat(5, 115px);
 grid-template-rows: auto ;
}</font>
</font>

效果如下:

如何使用CSS Grid布局实现网格的流动

在线案例

或许你会感觉这并没有强大到哪呀,跟以前使用float有太多的变化吗?如果你觉得没有,那请继续往下阅读。

网格流动&mdash;&mdash;列

网格的自动流,在默认情况下都是以行来给元素布局,也就是说grid-auto-flow取值为row。让网格单元格沿着行布局,直到没有可放区域(列的方向),网格单元格会自动换行到下一行排列。哪怕没有显式的声明网格,浏览器也会为创建隐式网格的轨道,用来放自网格单元格。

在实际使用中,可以使用grid-auto-flow属性来做修改,只需要把其默认值row设置成column。网格中的单元将会按列显示,如果需要,还会自动添加列。

一起来看一个示例,你将更易理解:

代码如下:


.wrapper {
 width: 560px;
 border: 1px solid orange;
 padding: 15px;
 margin: 20px auto;
 display: grid;
 grid-template-columns: repeat(6, 115px);
 grid-template-rows: 115px  115px 115px;
 grid-auto-flow: column;
}

效果如下:

如何使用CSS Grid布局实现网格的流动

在线案例

网格流与定位元素

前两介绍的都是网格容器所有子元素都是按照网格自动流排列。从上面简单的示例中可以得知,只要是网格容器中的子元素,通过grid-auto-flow都可以让其在网格容器中按列,或按行自动排列。可往往有些时候,有些网格需要做一些特殊定位处理。如果其中某个或某几个网格做了特殊处理,那么其他网格还会自动排列?我们将带着这个问题来一起看一个简单的示例:

代码如下:

<code>.wrapper { width: 560px; border: 1px solid orange; padding: 15px; margin: 20px auto; display: grid; grid-template-columns: repeat(5, 115px); grid-template-rows: auto ;}.b { grid-column: 3 / 6; grid-row: 2 / 3; outline: 2px solid red;}.f { grid-area: 3 / 1 / 4 / 6; background-color: #f36; outline: 2px solid red;}</code>

效果如下:

如何使用CSS Grid布局实现网格的流动

在线案例

在这个示例中,盒子.b,通过网格线,将B重新定位新位置上,但这样并没有影响网格的自动流。.b所在的默认位置将由其后面的.c元素补上。同样的,.f元素重新定位后,别的元素补上。而且.f扩展占有多个网格单元格,那么其他的单元格就会自动往后移。如上图所示。

总结

文章中通过简单示例向大家演示了CSS Grid Layout中网格单元格自动排列的实现方法,以及如何通过grid-auto-flow来显式设置自动排列的方向。最后用一个示例向大家展示了,自动排列的网格中,其中某个或某向个网格单元格显式定位后,是否会对网格自动流造成一定的影响。不过如果你看到最后一个示例时,你将不会再质问这个问题。因为效果告诉你一切。

另外网格自动流配合margin和媒体查询将能更好实现Web中相册相关布局,产品展示相关布局。当然你也还可以在这个基础上扩展出更有意义的布局效果。

感谢各位的阅读,以上就是“如何使用CSS Grid布局实现网格的流动”的内容了,经过本文的学习后,相信大家对如何使用CSS Grid布局实现网格的流动这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: 如何使用CSS Grid布局实现网格的流动

本文链接: https://www.lsjlt.com/news/76162.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何使用CSS Grid布局实现网格的流动
    这篇文章主要讲解了“如何使用CSS Grid布局实现网格的流动”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何使用CSS Grid布局实现网格的流动”吧!...
    99+
    2022-10-19
  • 如何使用CSS Grid布局网格单元格
    本篇内容介绍了“如何使用CSS Grid布局网格单元格”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!定义一...
    99+
    2022-10-19
  • 如何理解CSS Grid布局中的网格布局
    本篇内容主要讲解“如何理解CSS Grid布局中的网格布局”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何理解CSS Grid布局中的网格布局”吧!为什么我们...
    99+
    2022-10-19
  • 如何使用HTML和CSS实现瀑布流网格布局
    瀑布流网格布局是一种常见的布局方式,可以使网页元素呈现出类似瀑布流般的效果,给用户带来更好的视觉体验。本文将介绍如何使用HTML和CSS实现瀑布流网格布局,并提供具体的代码示例。首先,我们需要准备一些HTML结构和CSS样式。下面是一个基本...
    99+
    2023-10-21
    CSS html 瀑布流
  • 如何使用css实现网格布局
    这篇“如何使用css实现网格布局”除了程序员外大部分人都不太理解,今天小编为了让大家更加理解“如何使用css实现网格布局”,给大家总结了以下内容,具有一定借鉴价值,内容详细步骤清晰,细节处理妥当,希望大家通...
    99+
    2022-10-19
  • HTML教程:如何使用Grid布局实现栅格布局
    在前端开发中,实现栅格布局是非常常见的需求,通过栅格布局可以灵活地排列网页中的各个元素,使页面美观且具有响应式布局。而在HTML中,我们可以使用Grid布局来实现栅格布局。本文将详细介绍如何使用Grid布局来实现栅格布局,并提供具体的代码示...
    99+
    2023-10-21
    html Grid布局 栅格布局
  • HTML教程:如何使用Grid布局进行栅格网格布局
    网页布局是网页设计的重要组成部分,合理的网页布局可以提升用户的浏览体验。而Grid布局是现代网页布局中非常重要的一种技术,它可以帮助我们轻松地实现栅格网格布局。在本文中,我们将学习如何使用HTML和CSS的Grid布局来创建栅格网格布局,并...
    99+
    2023-10-21
    布局 HTML教程:Grid布局 栅格网格
  • HTML教程:如何使用Grid布局进行网格布局
    引言:在现代的网页设计中,网格布局是一种非常流行和实用的布局方式。它能够帮助开发者更加灵活地控制网页的布局和排版,使得网页呈现出更加美观和易读的效果。本文将向大家介绍如何使用HTML中的Grid布局进行网格布局,并提供具体的代码示例,帮助读...
    99+
    2023-10-21
    HTML:Grid布局
  • HTML教程:如何使用Grid布局进行栅格网格项布局
    引言:在Web开发中,布局是一个至关重要的方面。而Grid布局是一种非常强大和灵活的方式,用于创建栅格网格项布局。本文将介绍如何使用Grid布局来构建网页布局,并提供一些具体的代码示例,帮助你更好地理解和应用Grid布局。第一部分:Grid...
    99+
    2023-10-21
    html 布局 Grid
  • CSS自定义属性+CSS Grid网格实现超级的布局能力
    最近我还注意到的一件事就是CSS自定义属性。CSS自定义属性的工作方式有点像SASS和其他预处理器中的变量,主要的区别在于其它方法都是在浏览器中编译后生成,还是原本的CSS写法。CSS自定义属性是真正的动态变量,可以在样式表中或使用java...
    99+
    2023-06-03
  • HTML教程:如何使用Grid布局进行网格项布局
    HTML教程:如何使用Grid布局进行网格项布局Grid布局是一种强大的CSS网格系统,可以轻松地实现复杂的网格布局。通过将网格划分为行和列,我们可以方便地控制网格项的位置和大小。本教程将介绍如何使用Grid布局进行网格项布局,同时提供具体...
    99+
    2023-10-27
    HTML教程:Grid布局
  • HTML教程:如何使用Grid布局进行自适应网格自动布局
    HTML教程:如何使用Grid布局进行自适应网格自动布局,需要具体代码示例导语在Web开发中,网格布局(Grid layout)是一种更为灵活和强大的布局系统。它允许开发者将页面划分为网格单元,并通过定义行列的数量和大小来控制元素在这些单元...
    99+
    2023-10-26
    html 布局 Grid
  • css如何使用网格布局实现居中
    小编给大家分享一下css如何使用网格布局实现居中,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!网格布局实现居中  .outer&...
    99+
    2022-10-19
  • HTML教程:如何使用Grid布局进行栅格平均网格布局
    在前端开发中,网格布局(Grid Layout)是一种非常强大和灵活的布局方式。它可以使我们更轻松地创建栅格布局,实现页面的响应式设计。本文将介绍如何使用Grid布局进行栅格平均网格布局,并提供具体的代码示例。创建HTML结构首先,我们需要...
    99+
    2023-10-21
    HTML教程:Grid布局 栅格 平均网格布局
  • HTML教程:如何使用Grid布局进行栅格自适应网格布局
    HTML教程:如何使用Grid布局进行栅格自适应网格布局,需要具体代码示例引言:随着互联网的发展,网页布局变得越来越重要。传统的网页布局方法,如使用表格或浮动布局,往往需要大量的代码和调整来实现自适应的效果。而CSS3中引入的Grid布局则...
    99+
    2023-10-27
    html 关键词: Grid布局 栅格自适应
  • 如何使用CSS Positions布局实现弹性网格
    CSS Positions布局是网页布局中常用的一种方式,它可以实现弹性网格的效果,让网页元素在不同设备上自适应显示。在本文中,我们将介绍如何使用CSS Positions布局来实现弹性网格,并提供具体的代码示例。一、理解CSS Posit...
    99+
    2023-10-21
    布局 CSS Positions 弹性网格
  • HTML教程:如何使用Grid布局进行自适应网格布局
    HTML教程: 如何使用Grid布局进行自适应网格布局在前端开发中,网页布局是一个重要的环节。而在现代的网页布局中,Grid布局已经成为了一种非常流行的选择。它可以帮助我们快速、灵活地构建各种网格布局,并且能够实现自适应的效果。本篇文章将介...
    99+
    2023-10-27
    HTML教程:Grid布局
  • 如何使用纯css实现瀑布流布局
    这篇文章主要为大家展示了“如何使用纯css实现瀑布流布局”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用纯css实现瀑布流布局”这篇文章吧。   1、纯...
    99+
    2022-10-19
  • 如何使用Css Flex 弹性布局实现瀑布流布局
    随着网页设计的不断发展,瀑布流布局成为了一种非常流行的页面布局方式。与传统的网格布局不同,瀑布流布局能够自适应屏幕大小,并且呈现出独特的流动感。在本文中,我们将介绍如何使用CSS Flex 弹性布局来实现瀑布流布局,并提供具体的代码示例。C...
    99+
    2023-10-21
    瀑布流布局 弹性布局 CSS flex
  • HTML教程:如何使用Grid布局进行自适应网格项布局
    在现代的网页设计中,自适应布局是至关重要的。通过自适应布局,网页可以在不同的设备和屏幕上呈现出最佳的显示效果,提供更好的用户体验。在这方面,CSS Grid布局是一种强大的工具,可以帮助我们实现网页布局的自适应性。本文将介绍如何使用Grid...
    99+
    2023-10-21
    自适应 html Grid布局
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作