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

最新一段时间对照喜欢玩弄图表,出于好奇,我想找出对照好的用 CSS 制作图表的方案。最先学习网上开源图表库,它对我学习新的和不熟悉的前端手艺很有辅助,好比这个:CSS Grid。

今天和人人分享我学到的新知识:若何用 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 布局制作一个响应式柱状图

Jmeter(三) – 从入门到精通 – 测试计划(Test Plan)的元件(详解教程)

我们告诉每个柱状图从网格的顶部(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 来绑定真实的营业数据等。

原创文章,作者:admin,如若转载,请注明出处:https://www.2lxm.com/archives/11869.html