• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >css3 > 使用CSS Grid布局实现网格的流动

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

作者:佚名 字体:[增加 减小] 来源:互联网 时间:2017-06-02

本文主要包含css grid布局,css grid,css中grid,grid网格布局,grid布局等相关知识,佚名 希望在学习及工作中可以帮助到您

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

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

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

网格的自动流

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

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

HTML


CSS


margin: 20px auto;</p> <p> display: grid;
grid-template-columns: repeat(5, 100px);
grid-template-rows: auto ;
}
</div>

效果如下:

在线案例

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

在线案例

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

上图中可以得知,在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属性值:


在线案例

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

网格流动——列

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

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

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


在线案例

网格流与定位元素

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


在线案例

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

总结

文章中通过简单示例向大家演示了CSS Grid Layout中网格单元格

您可能想查找下面的文章:

  • CSS Grid布局教程之网格单元格布局
  • CSS Grid布局教程之浏览器开启CSS Grid Layout汇总
  • CSS Grid布局教程之什么是网格布局
  • 使用CSS Grid布局实现网格的流动

相关文章

  • 2017-06-02css3的@media属性实现页面响应式布局示例代码
  • 2017-06-02纯CSS3实现图片无间断轮播效果
  • 2017-06-02CSS3,线性渐变(linear-gradient)的使用总结
  • 2017-06-02推荐10个CSS3 制作的创意下拉菜单效果
  • 2017-06-02CSS3 icon font完全指南(CSS3 font 会取代icon图标)
  • 2017-06-02详解CSS3阴影 box-shadow的使用和技巧总结
  • 2017-06-02CSS3旋转——彩色扇子兼容firefox浏览器
  • 2017-06-02使用CSS3的ruby-position固定注音位置的用法示例
  • 2017-06-02CSS实现限制字数功能当对象内文本溢出时显示省略标记
  • 2017-06-02css3隔行变换色实现示例

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • css3实现背景颜色渐变让图片不再是唯一的实现方式
    • 用CSS3的box-reflect设置文字倒影效果的方法讲解
    • css3气泡 css3关键帧动画创建的动态通知气泡
    • 灵活运用CSS3特性绘制简易版围棋效果
    • CSS3实现自定义Checkbox特效实例代码
    • CSS3 animation实现逐帧动画效果
    • 实现CSS3中的border-radius(边框圆角)示例代码
    • 一款基于css3的动画按钮代码教程
    • CSS3的常见transformation图形变化用法小结
    • css3背景图片透明叠加属性cross-fade简介及用法实例

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有