最新一段时间比较喜欢玩弄图表,出于好奇,我想找出比较好的用 CSS 制作图表的方案。开始学习网上开源图表库,它对我学习新的和不熟悉的前端技术很有帮助,比如这个: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;
}

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

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

理解网格线

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;
}

效果:

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

用 CSS Grid 布局制作一个响应式柱状图的更多相关文章

  1. 快速使用CSS Grid布局,实现响应式设计

    常用Grid布局属性介绍 下面从一个简单Grid布局例子说起. CSS Grid 布局由两个核心组成部分是 wrapper(父元素)和 items(子元素). wrapper 是实际的 grid(网格 ...

  2. CSS Grid布局,实现响应式设计

    columns(列) 和 rows(行) 为了使其成为二维的网格容器,我们需要定义列和行.让我们创建3列和2行.我们将使用grid-template-row和grid-template-column属 ...

  3. CSS Grid 布局完全指南(图解 Grid 详细教程)

    CSS Grid 布局是 CSS 中最强大的布局系统.与 flexbox 的一维布局系统不同,CSS Grid 布局是一个二维布局系统,也就意味着它可以同时处理列和行.通过将 CSS 规则应用于 父元 ...

  4. CSS Grid 布局

    CSS Grid 布局是 CSS 中最强大的布局系统.与 flexbox 的一维布局系统不同,CSS Grid 布局是一个二维布局系统,也就意味着它可以同时处理列和行.通过将 CSS 规则应用于 父元 ...

  5. CSS Grid 布局学习笔记

    CSS Grid 布局学习笔记 好久没有写博客了, MDN 上关于 Grid 布局的知识比较零散, 正好根据我这几个月的实践对 CSS Grid 布局做一个总结, 以备查阅. 1. 基础用法 Grid ...

  6. CSS Grid布局指南

    简介 CSS Grid布局 (又名"网格"),是一个基于二维网格布局的系统,主要目的是改变我们基于网格设计的用户接口方式.如我们所知,CSS 总是用于网页的样式设置,但它并没有起到 ...

  7. AudioPlayer.js,一个响应式且支持触摸操作的jquery音频插件

    AudioPlayer.js是一个响应式.支持触摸操作的HTML5 的音乐播放器.本文是对其官网的说用说明文档得翻译,博主第一次翻译外文.不到之处还请谅解.之处. JS文件地址:http://osva ...

  8. 带你入门 CSS Grid 布局

    前言 三月中旬的时候,有一个对于 CSS 开发者来说很重要的消息,最新版的 Firefox 和 Chrome 已经正式支 CSS Grid 这一新特性啦.没错:我们现在就可以在最流行的两大浏览器上玩转 ...

  9. 使用jQuery开发一个响应式超酷整合RSS信息阅读杂志

    在线演示1 本地下载     申请达人,去除赞助商链接 如果大家喜欢阅读博客文章的话,可能都会使用RSS阅读器,今天这里我们将使用jQuery来开发一个响应式的RSS信息阅读应用,使用它你可以将你喜欢 ...

随机推荐

  1. 全网最简单明了的MySQL连接Eclipse方法(JDBC详细安装方式及简单操作)2020新版

    Step 1 你得有Eclipse 没有出门右拐,我教不了你. Step 2 你得有Mysql MySQL的详细安装过程,我在另一篇博客中给出.戳我 Step 3 安装JDBC 可以去官网下,如果用的 ...

  2. CF思维联系– Codeforces-988C Equal Sums (哈希)

    ACM思维题训练集合 You are given k sequences of integers. The length of the i-th sequence equals to ni. You ...

  3. 网络流--最大流--Dinic模板矩阵版(当前弧优化+非当前弧优化)

    //非当前弧优化版 #include <iostream> #include <cstdio> #include <math.h> #include <cst ...

  4. 数据结构--队列(Java实现)

    数据结构--队列(Java实现) 博客说明 文章所涉及的资料来自互联网整理和个人总结,意在于个人学习和经验汇总,如有什么地方侵权,请联系本人删除,谢谢! 简介 队列是一种特殊的线性表,特殊之处在于它只 ...

  5. tp5中提示错误A non well formed numeric value encountered

    问题因为自动完成时间导致的 原来我的数据库是这样的 修改成下面这样就好了

  6. redis文章汇总

    方便集群管理时的查看操作 http://www.cnblogs.com/mushroom/p/4738170.html http://www.cnblogs.com/hjwublog/p/568170 ...

  7. 帝国cms 批量替换 字段内容包含的 指定的 关键字 SQL命令

    帝国cms 批量替换 字段内容包含的 指定的 关键字update phome_ecms_news_data_1 set newstext=replace(newstext,'原来','现在');

  8. 记录下做攻防世界的misc题

    0x00 记录一下,代表自己做过 0x01 flag_universe 看简介是来自2018年的百越杯. 将文件下载下来后,就一个flag_universe.pcapng文件,wireshark打开. ...

  9. Gradle 多环境、多渠道打包

    最近项目从eclipse迁移到AS上,主要是为了使用gradle这个插件进行apk打包.毕竟程序员还是要与时俱进的.首先介绍下项目主要需求: 1.使用百度统计,需要对个平台的信息进行统计 2..api ...

  10. Codeforces 1105D(Kilani and the Game,双队列bfs)

    AC代码: #include<bits/stdc++.h> #define ll long long #define endl '\n' #define mem(a,b) memset(a ...