您现在的位置是:网站首页> 编程资料编程资料
使用CSS Grid布局实现网格的流动CSS Grid布局教程之网格单元格布局CSS Grid布局教程之浏览器开启CSS Grid Layout汇总CSS Grid布局教程之什么是网格布局css 限定GridView宽度并加上滚动条YUI 中的 Grids CSS值得关注和学习的-CSS教程-网页制作-网页教学网5分钟教你学会 CSS Grid 布局
2021-09-05
850人已围观
简介 这篇文章主要介绍了使用CSS 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
.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;
display: grid;
grid-template-columns: repeat(5, 100px);
grid-template-rows: auto ;
}
效果如下:
不过离文章所示效果还是略有差距,每个.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
属性值:
.wrapper {
width: 560px;
border: 1px solid orange;
padding: 15px;
margin: 20px auto;
display: grid;
grid-template-columns: repeat(5, 115px);
grid-template-rows: auto ;
}
效果如下:
或许你会感觉这并没有强大到哪呀,跟以前使用float
有太多的变化吗?如果你觉得没有,那请继续往下阅读。
网格的自动流,在默认情况下都是以行来给元素布局,也就是说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;
}
效果如下:
前两介绍的都是网格容器所有子元素都是按照网格自动流排列。从上面简单的示例中可以得知,只要是网格容器中的子元素,通过grid-auto-flow
都可以让其在网格容器中按列,或按行自动排列。可往往有些时候,有些网格需要做一些特殊定位处理。如果其中某个或某几个网格做了特殊处理,那么其他网格还会自动排列?我们将带着这个问题来一起看一个简单的示例:
.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;}
效果如下:
在这个示例中,盒子.b
,通过网格线,将B
重新定位新位置上,但这样并没有影响网格的自动流。.b
所在的默认位置将由其后面的.c
元素补上。同样的,.f
元素重新定位后,别的元素补上。而且.f
扩展占有多个网格单元格,那么其他的单元格就会自动往后移。如上图所示。
文章中通过简单示例向大家演示了CSS Grid Layout中网格单元格自动排列的实现方法,以及如何通过grid-auto-flow
来显式设置自动排列的方向。最后用一个示例向大家展示了,自动排列的网格中,其中某个或某向个网格单元格显式定位后,是否会对网格自动流造成一定的影响。不过如果你看到最后一个示例时,你将不会再质问这个问题。因为效果告诉你一切。
另外网格自动流配合margin
和媒体查询将能更好实现Web中相册相关布局,产品展示相关布局。当然你也还可以在这个基础上扩展出更有意义的布局效果。
相关内容
- 纯css3制作网站后台管理面板ai怎么使用CSS属性面板?Dreamweaver中CSS面板该怎么设置?CSS 实现侧滑显示留言面板的网页组件功能
- 浅谈合理架构CSS纯CSS实现家谱树 组织架构树同理 代码分享我的css架构理念—因人而异 没有最优 只有适合
- CSS Sprite从大图中截取小图完整教程css sprites把很多小图集成在一张图片上CSS Sprites 样式生成工具 3.0CSS Sprites简介以及优缺点使用CSS sprite 的好处和坏处分析什么是CSS Sprites(图片合并)技术 图文介绍CSS Sprites详解css sprites技术 CSS Sprites图片切割术与图片优化深入理解浅谈CSS Sprites切图技术
- CSS制作清爽绿色格调图文box通用样式CSS 网页图文混排的10个技巧CSS 网页布局中的图文列表实现代码javascript+CSS 联合打造图文结合动感菜单div css图文混排列表设计中的基础问题总结
- 一款纯css3实现的鼠标悬停动画按钮纯CSS3实现的鼠标悬停图标旋转导航动画特效源码纯css3实现的鼠标悬停背景翻转动画导航特效源码一款纯CSS3实现的鼠标悬停动画按钮集合特效源码 HTML5+CSS3实现的鼠标悬停动画菜单按钮特效源码 纯css3实现的鼠标悬停动画按钮一款基于CSS3实现的鼠标悬停图片动画及多种文字动画效果源码31款纯css3实现的鼠标悬停动画效果源码纯CSS3实现的鼠标悬停图片文字动画效果源码CSS3鼠标悬停动画显示文字特效源码
- 一款纯css3制作的2015年元旦雪人动画特效教程css3中transform属性实现的4种功能详解CSS3.0(Cascading Style Sheet) 层叠级联样式表纯CSS3实现div按照顺序出入效果CSS3实现列表无限滚动/轮播效果css3 利用transform-origin 实现圆点分布在大圆上布局及旋转特效CSS3实现的侧滑菜单CSS3实现的3D隧道效果用CSS3画一个爱心css3 实现文字闪烁效果的三种方式示例代码六种css3实现的边框过渡效果
- 一款利用css3的鼠标经过动画显示详情特效的实例教程css3中transform属性实现的4种功能详解CSS3.0(Cascading Style Sheet) 层叠级联样式表纯CSS3实现div按照顺序出入效果CSS3实现列表无限滚动/轮播效果css3 利用transform-origin 实现圆点分布在大圆上布局及旋转特效CSS3实现的侧滑菜单CSS3实现的3D隧道效果用CSS3画一个爱心css3 实现文字闪烁效果的三种方式示例代码六种css3实现的边框过渡效果
- 纯css3实现照片墙效果纯css实现照片墙3D效果的示例代码CSS3制作漂亮的照片墙的实现代码CSS3制作精致的照片墙特效CSS3实现漂亮的照片墙效果的简单实例(推荐)CSS3实现鼠标悬停照片墙放大特效源码CSS3简单实现照片墙CSS3实现的悬挂照片墙效果源码jquery+css3实现非常大气的瀑布流照片墙特效利用css制作3D照片墙效果
- 纯css3实现走马灯效果css3中transform属性实现的4种功能详解CSS3.0(Cascading Style Sheet) 层叠级联样式表纯CSS3实现div按照顺序出入效果CSS3实现列表无限滚动/轮播效果css3 利用transform-origin 实现圆点分布在大圆上布局及旋转特效CSS3实现的侧滑菜单CSS3实现的3D隧道效果用CSS3画一个爱心css3 实现文字闪烁效果的三种方式示例代码六种css3实现的边框过渡效果
- CSS3实现的炫酷菜单代码分享基于jquery+css3的固定的网页底部的炫酷工具条使用简单的CSS3属性实现炫酷读者墙效果一款既炫酷又实用的jQuery+CSS3多张图片选择动画特效5种CSS3炫酷效果的自定义Checkbox特效代码CSS3与SVG实现文字背景动画炫酷特效源码纯CSS3实现炫酷卡通人物面部表情动画效果源码CSS3+SVG实现的炫酷发光特效进度条Loading动画源码