iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >如何使用CSS Grid布局制作一个响应式柱状图
  • 106
分享到

如何使用CSS Grid布局制作一个响应式柱状图

2023-06-08 04:06:43 106人浏览 独家记忆
摘要

这篇文章主要介绍了如何使用CSS Grid布局制作一个响应式柱状图,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。先上效果图:第一个简单版本第一眼看上去可能会有点不知道怎么开始

这篇文章主要介绍了如何使用CSS Grid布局制作一个响应式柱状图,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

先上效果图:

如何使用CSS Grid布局制作一个响应式柱状图

第一个简单版本

第一眼看上去可能会有点不知道怎么开始,因此我们先来关注如何创建一个简单的版本。首先,我们需要为图表编写 html 标签:

<div class="chart">  <div class="bar-1"></div>  <div class="bar-2"></div>  <div class="bar-3"></div>  <div class="bar-4"></div>  <!-- 一直到 bar-12 --></div>

这些 bar- 开头的 div 标签将对应柱状图中的一条柱子,整篇文章所需要的 HTML 就这么多。

现在按照我的步骤和简单的解说一步一步用 CSS 把柱状图大概的样式画出来,不用过多地担心下面出现的可能对你有些陌生的 CSS 语义,稍后我们将重点介绍关于 CSS Grid 的知识。

好了,现在开始我们的 CSS 样式编写。我们先对父元素添加一些必要的样式:

* {  box-sizing: border-box;}html,body {  margin: 0;  background-color: #eee;  display: flex;  justify-content: center;}.chart {  height: 100vh;  width: 70vw;}

我们需要在图表中有 12 个条形,中间有 5px 的间距,按此需求,我们可以对父类 .chart 编写如下 Grid 相关的样式:

.chart {  display: grid;  grid-template-columns: repeat(12, 1fr);  grid-template-rows: repeat(100, 1fr);  grid-column-gap: 5px;}

对于熟悉 Grid 布局的人来说,这是非常简单的。上面代码表达的是:“我想要 12 列,每个子元素具有相同的宽度(1fr = 1 fraction),高度分为 100 等分,1 等分为一行(这样方便计算),它们之间有 5px 的间隔。”

到这里,我们的图表仍然是空的,因为我们没有告诉我们的子元素如何去占用网格中的空间。我们使用 grid-row-startgrid-row-end 属性来填充网格中的垂直空间,后而我们将通过改变这两个属性来定义各个子元素自己的高度。为样式类为 bar 开头子元素添加如下样:

[class*='bar'] {  grid-row-start: 1;  grid-row-end: 101;  border-radius: 5px 5px 0 0;  background-color: #ff4136;}

现在可以得到这样的效果:

如何使用CSS Grid布局制作一个响应式柱状图

我们告诉每个柱状图从网格的顶部(1)开始,然后在底部(101)结束。上面我们把网格划分了 100 行,为什么要使用 101 作为该属性的值呢?如果你被这些 Grid 属性搞蒙了,没关系!在我们继续之前,让我们对此进行一点探讨。

理解网格线

Grid 布局的一个特殊之处就是网格线的概念,这对理解这个新的布局工具非常重要。以下是网格线在四行四列网格中绘制的示意图:

如何使用CSS Grid布局制作一个响应式柱状图

这四行四列的对应的样式是这样的(特殊的黑色区域对应的样式类为 special-col):

.grid {  grid-gap: 5px;  grid-template-columns: repeat(4, 1fr);  grid-template-rows: repeat(4, 1fr);}.special-col {  grid-row: 2 / 4;  background-color: #333;}

grid-rowgrid-row-startgrid-row-end 的简写属性,前者表示元素在网格中的开始位置,后者表示元素在网格中的结束位置。注意到没,黑色块是从第 2 条网格线开始的,并在第 4 条网格线结束(而不是在第 4 行)。如果我们想让那个黑盒子填满所有 4 行,那么我们需要在第 5 条网格线结束,即:1 / 5。理解这一点很重要。

换句话说,我们不应该认为子元素在一个网格中占据整个行或列,而应该只跨越这些网格线的。我花了不少时间才从概念上理解并习惯了这一点,因为我最近深入研究了 Jen Simmons 关于这个问题的教程

回到示例

这就是为什么在我们上面的图表示例中,所有列都在 101 这个值结束,因为 101 代表的是第 101 条网络线,而不是第 100 行。

现在,由于我们的 .chart 使用了 vw/vh 单位,也就有了一个响应良好的图表,不需要再做其它的额外工作来支持响应式。如果你调整浏览器大小,你会发现它可以很好地压缩或延伸,它总是占据整个视窗。

理解了网络线的概念,我们就可以很轻松地为柱子调整高度了,我们需要让各柱子高度参差不一。

.bar-1 {  grid-row-start: 55;}.bar-2 {  grid-row-start: 1;}...(略);

最后我们使寄偶数的柱子颜色不一样:

[class*='bar']:nth-child(odd) {  background-color: #ff4136;}[class*='bar']:nth-child(even) {  background-color: #0074d9;}

效果:

如何使用CSS Grid布局制作一个响应式柱状图

我们就这样制作完成了一个支持响应式的柱状图。当然,这个示例只是一个开始,距离要达到实际应用的效果还有很多事情要做。比如画标注和轴、通过 js 来绑定真实的业务数据等。

感谢你能够认真阅读完这篇文章,希望小编分享的“如何使用CSS Grid布局制作一个响应式柱状图”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网精选频道,更多相关知识等着你来学习!

--结束END--

本文标题: 如何使用CSS Grid布局制作一个响应式柱状图

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

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

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

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

下载Word文档
猜你喜欢
  • 如何使用CSS Grid布局制作一个响应式柱状图
    这篇文章主要介绍了如何使用CSS Grid布局制作一个响应式柱状图,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。先上效果图:第一个简单版本第一眼看上去可能会有点不知道怎么开始...
    99+
    2023-06-08
  • 如何使用HTML和CSS创建一个响应式图库布局
    引言:随着移动设备的普及,响应式设计成为了网页设计的重要考虑因素之一。而在开发一个图库网站时,如何设计一个兼具美观和响应式布局的页面,将成为重要的问题。本文将详细讨论如何使用HTML和CSS来创建一个响应式图库布局,并且提供具体的代码示例。...
    99+
    2023-10-21
    响应式 CSS html
  • 如何使用HTML和CSS创建一个响应式图片墙布局
    如何使用HTML和CSS创建一个响应式图片墙布局引言:随着移动互联网的普及,响应式设计成为了网页设计的重要标准。在网页设计中,图片墙布局是常见的一种布局形式,它可以以瀑布流的形式展示不同尺寸的图片。本文将介绍如何使用HTML和CSS创建一个...
    99+
    2023-10-25
    HTML CSS 响应式 图片墙
  • 如何使用HTML和CSS创建一个响应式轮播图布局
    在现代的网页设计中,轮播图是一个常见的元素。它能够吸引用户的注意力,展示多个内容或图片,并且能够自动切换。在本文中,我们将介绍如何使用HTML和CSS创建一个响应式的轮播图布局。首先,我们需要创建一个基本的HTML结构,并添加所需的CSS样...
    99+
    2023-10-21
    轮播图 响应式 CSS html 布局
  • 如何使用HTML和CSS创建一个响应式图片轮播布局
    如何使用HTML和CSS创建一个响应式图片轮播布局在现代网页设计中,轮播图已经成为了很重要的元素之一。它可以有效地展示多张图片,并通过轮播的效果吸引用户的注意力。本文将介绍如何使用HTML和CSS来创建一个响应式图片轮播布局,并提供具体的代...
    99+
    2023-10-25
    CSS html - 布局 - 图片 - 轮播
  • 如何使用HTML和CSS创建一个响应式图片画廊布局
    在现代的网页设计中,响应式设计已经成为一个非常重要的概念。随着移动设备的普及,人们对于在不同设备上浏览网页的需求也愈发增加。在本文中,我将详细介绍如何使用HTML和CSS创建一个响应式的图片画廊布局。首先,我们需要准备一些HTML结构来构建...
    99+
    2023-10-21
    响应式 CSS html 图片 画廊布局
  • 如何使用HTML和CSS创建一个响应式图片格子布局
    如何使用HTML和CSS创建一个响应式图片格子布局在当前移动设备日益普及的时代,为了更好地展示图片内容和适应不同的屏幕尺寸,响应式设计变得越来越重要。在本文中,将介绍如何使用HTML和CSS创建一个响应式的图片格子布局,以展示图片并使其在不...
    99+
    2023-10-27
    响应式 CSS html 图片 布局
  • 如何使用HTML和CSS创建一个响应式图标展示布局
    随着移动设备的普及,响应式设计已经成为了网页设计的标准之一。在设计网页时,我们需要确保网页能够在不同尺寸的设备上展示良好,并且能够适应不同的屏幕大小。本文将介绍如何使用HTML和CSS来创建一个简单的响应式图标展示布局,并提供具体的代码示例...
    99+
    2023-10-21
    CSS html 响应式布局
  • 如何使用HTML和CSS创建一个响应式图片滤镜布局
    在今天的数字时代,网页设计变得越来越重要。而图片作为网页设计中的重要组成部分,扮演着非常重要的角色。为了使网页更具吸引力和魅力,我们经常使用图片滤镜来增强图片的效果。本文将介绍如何使用HTML和CSS创建一个响应式的图片滤镜布局,并提供具体...
    99+
    2023-10-21
    CSS html 响应式布局
  • 如何使用HTML和CSS创建一个响应式图片导航布局
    HTML和CSS是创建网页布局的重要工具。通过使用HTML的结构标签和CSS的样式规则,我们可以创建出各种各样的页面布局。在本文中,我们将学习如何使用HTML和CSS创建一个响应式图片导航布局。首先,让我们来编写HTML代码。<!DO...
    99+
    2023-10-21
    响应式 CSS html
  • 如何使用HTML和CSS创建一个响应式图片展示布局
    在现代Web设计中,响应式布局已经成为一种标配,因为越来越多的人使用不同尺寸和分辨率的设备浏览网页。在本文中,我们将介绍如何使用HTML和CSS来创建一个响应式图片展示布局。首先,我们需要一个HTML文件来构建页面结构。在该文件中,我们使用...
    99+
    2023-10-21
    响应式 CSS html
  • 如何使用HTML和CSS创建一个响应式图片集锦布局
    在现代网页设计中,响应式布局是至关重要的。随着不同尺寸和设备的使用,网页需要能够自适应地调整布局和元素的大小。在这篇文章中,我们将学习如何使用HTML和CSS来创建一个响应式的图片集锦布局。HTML结构首先,我们需要定义HTML结构。假设我...
    99+
    2023-10-21
    CSS html 响应式布局
  • 如何使用HTML和CSS创建一个响应式图片网格布局
    如何使用HTML和CSS创建一个响应式图片网格布局在当今的互联网时代,图片占据了网络内容的重要一部分。为了展示各种类型的图片,我们需要一个有效且美观的网格布局。在本文中,我们将学习如何使用HTML和CSS创建一个响应式的图片网格布局。首先,...
    99+
    2023-10-27
    响应式 CSS html 图片 网格布局
  • 如何使用HTML和CSS创建一个响应式图片滑块布局
    导语:响应式网页设计已经成为了现代网页开发的常态,而图片滑块布局则是一个十分常见的设计元素。本文将介绍如何使用HTML和CSS来创建一个简单的响应式图片滑块布局,并提供具体的代码示例。一、HTML结构首先,我们需要创建一个基本的HTML结构...
    99+
    2023-10-21
    响应式 CSS html 布局 图片滑块
  • 如何使用HTML和CSS创建一个响应式图片展示墙布局
    HTML和CSS是前端开发中常用的技术,可以用来创建各种布局效果。在本文中,我们将学习如何使用HTML和CSS来创建一个响应式的图片展示墙布局,让图片在不同设备上都能够自适应显示。首先,我们需要创建一个HTML文件,命名为index.htm...
    99+
    2023-10-21
    响应式 CSS html
  • 如何使用HTML和CSS创建一个响应式图片导航栏布局
    如何使用HTML和CSS创建一个响应式图片导航栏布局随着移动设备的普及,响应式设计已经成为了网页设计的基本要求。在网页制作中,导航栏是一个非常重要的组件。本文将介绍如何使用HTML和CSS创建一个响应式图片导航栏布局,具体代码示例如下:HT...
    99+
    2023-10-25
    CSS html 响应式布局
  • 怎么在css中利用Flex制作一个柱状图
    怎么在css中利用Flex制作一个柱状图?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。HTML:<div class="his_box...
    99+
    2023-06-08
  • 如何使用HTML和CSS创建一个响应式博客布局
    在当今互联网时代,博客已经成为人们分享知识、经验和故事的重要平台。设计一个吸引人且具有响应式布局的博客,可以让你的内容更好地展示在不同尺寸和设备上,提升用户体验。本文将介绍如何使用HTML和CSS来创建一个响应式博客布局,同时提供具体的代码...
    99+
    2023-10-21
    CSS html 响应式布局
  • 如何使用HTML和CSS创建一个响应式表格布局
    如何使用HTML和CSS创建一个响应式表格布局HTML是一种用于构建网页结构的标记语言,而CSS则用于设置网页的样式和布局。在网页设计中,表格是一种常见的元素,用于以表格形式展示数据。本文将介绍如何使用HTML和CSS来创建一个响应式的表格...
    99+
    2023-10-27
    CSS html 响应式布局
  • 如何使用HTML和CSS创建一个响应式图片集锦展示布局
    在网页设计中,展示图片集锦是一种常见的需求。为了提供更好的用户体验,我们希望这些图片在不同设备上都能以适当的方式展示,而不仅仅是简单地缩放。这就需要设计一个响应式的图片集锦展示布局。在本文中,我们将介绍如何使用HTML和CSS来创建这样一个...
    99+
    2023-10-21
    响应式 CSS html
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作