如何使用CSS在线字体和D3实现Google的信息图

本篇文章给大家带来的内容是如何使用css在线字体和d3实现google的信息图 ,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

效果预览

3478026120-5b93aa0de1a80_articlex.png

源代码下载

https://github.com/comehope/front-end-daily-challenges

代码解读

定义 dom,只有 1 个空元素,其中不包含任何文本:

引入字体文件,Product Sans 是 Google 专门为品牌推广创建的无衬线字体:

@import url("https://fonts.googleapis.com/css?family=Product+Sans");

居中显示:

立即学习“前端免费学习笔记(深入)”;

body {    margin: 0;    height: 100vh;    display: flex;    align-items: center;    justify-content: center;}

用伪元素制作 logo,注意 content 的内容不是 "Google",而是 "google_logo"

.logo::before {    content: 'google_logo';    font-size: 10vw;}

设置字体,采用刚才引入的在线字体,刚才页面上的 "google_logo" 文字被替换成了单色的 logo 图案:

body {    font-family: 'product sans';}

定义颜色变量:

:root {    --blue: #4285f4;    --red: #ea4335;    --yellow: #fbbc05;    --green: #34a853;}

设置文字遮罩效果,为文字上色:

.logo::before {    background-image: linear-gradient(        to right,        var(--blue) 0%, var(--blue) 26.5%,         var(--red) 26.5%, var(--red) 43.5%,         var(--yellow) 43.5%, var(--yellow) 61.5%,        var(--blue) 61.5%, var(--blue) 78.5%,         var(--green) 78.5%, var(--green) 84.5%,         var(--red) 84.5%, var(--red) 100%    );    -webkit-background-clip: text;    -webkit-text-fill-color: transparent;}

至此,Google logo 制作完成,接下来制作 googol 信息,说明 Google 的名字来源于含义是 1 后面跟 100 个零的大数的单词 googol。

在 dom 中添加一行说明文本和容纳数字的容器,容器中包含 5 个数字,在每个数字的内联样式中指定了颜色变量:

The name of Google originated from a misspelling of the word "googol", the number 1 followed by 100 zeros.

1 0 0 0 0

设置说明文本的样式:

.desc {    font-size: 1.5vw;    font-weight: normal;    color: dimgray;    margin-top: 2em;}

设置数字的样式:

.zeros {    font-size: 3vw;    font-weight: bold;    margin-top: 0.2em;    text-align: center;    width: 25.5em;    word-wrap: break-word;}

为数字上色:

.zeros span {    color: var(--c);}

微调数字 "1" 的边距,让它不要和后面的 "0" 靠得太紧:

.zeros span:nth-child(1) {    margin-right: 0.2em;}

至此,静态布局完成,接下来用 d3 批量处理数字。

引入 d3 库,并删除掉 dom 中 .zeros 的数字子元素:


最终我们会在页面上显示 100 个 0,每个 0 的颜色都不同,并且为了美观,相邻数字的颜色也要不同。
所以,先定义一个获取颜色的函数,它可以从 Google logo 配色的 4 种颜色中取任意一个颜色,并且有一个表示被排除颜色的参数,当指定的此参数时,就从 4 个可选的颜色中去掉这个颜色,然后从剩下的 3 个颜色中随机取一个颜色:

function getColor(excludedColor) {    let colors = new Set(['blue', 'red', 'yellow', 'green'])    colors.delete(excludedColor)    return Array.from(colors)[Math.floor(d3.randomUniform(0, colors.size)())]}

然后,定义 2 个常量,ZEROS 是存储 100 个 0 的数组,ONE 是存储数字 1 的对象,它有 2 个属性,number 表示它的数值是 1,color 表示它的颜色是蓝色:

const ZEROS = d3.range(100).map(x=>0)const ONE = {number: 1, color: 'blue'}

接下来,通过用 reduce 函数遍历 ZEROS 数组,返回一个新的数组 numbers,它有 101 个元素(1 以及跟随它的 100 个 0),每个元素都是 1 个包含 numbercolor 属性的对象:

let numbers = ZEROS.reduce(function (numberObjects, d) {    numberObjects.push({        number: d,        color: getColor(numberObjects[numberObjects.length - 1].color)    })    return numberObjects}, [ONE])

然后,以 numbers 为数据源,用 d3 批量创建出 dom 元素,并且把颜色信息写在行内样式中:

d3.select('.zeros')    .selectAll('span')    .data(numberObjects)    .enter()    .append('span')    .style('--c', (d)=>`var(--${d.color})`)    .text((d)=>d.number)

最后,微调一下内容的边距,使整个内容居中:

.logo {    margin-top: -10vh;}

大功告成!

相关推荐:

如何使用纯CSS实现条纹错觉的动画效果(附源码)

CSS3文字特效属性text-shadow的介绍,实例讲解火焰文字效果

以上就是如何使用CSS在线字体和D3实现Google的信息图的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1611613.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 02:25:39
下一篇 2025年12月24日 02:25:51

相关推荐

  • 如何使用纯CSS实现一把剪刀的效果(附源码)

    本篇文章给大家带来的内容是关于如何使用纯css实现一把剪刀的效果(附源码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 效果预览 源代码下载 https://github.com/comehope/front-end-daily-challenges 代码解读 定义 dom,容器…

    2025年12月24日
    000
  • CSS中什么是BEM 命名规范?

    本章为大家带来css中什么是bem 命名规范?,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 一 什么是 BEM 命名规范 Bem 是块(block)、元素(element)、修饰符(modifier)的简写,由 Yandex 团队提出的一种前端 CSS 命名方法论。   &#82…

    好文分享 2025年12月24日
    000
  • css为select添加样式(无脚本)实现

    改变select默认的样式,一般情况下通过ul,li来模拟来实现。 有很多jquery插件就是通过这样的方式来改变select默认样式的。 根据程序哥哥那边的反映,此种方式在form提交后无法获取数据,后来经过实验,用了不同的js/jquery插件,都是同样的结果:无法获取数据。 后来看一篇外国人写…

    好文分享 2025年12月24日
    000
  • css实现双飞翼布局的四种方法(附代码)

    本篇文章给大家带来的内容是关于css实现双飞翼布局的四种方法(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 圣杯布局、双飞翼布局效果图 从效果图来看圣杯布局、双飞翼布局效果是一样一样的。圣杯布局、双飞翼布局就是左右两侧宽度固定,中间内容宽度自适应,即100% 圣杯布局 *…

    2025年12月24日
    000
  • CSS入门教程之margin属性

    设置外边距的最简单的办法就是运用 margin属性。margin用于设置对象标签之间间隔距离,比方2个上下排列的div盒子,我们就能够运用margin款式完成上下2个盒子间距。margin 属性承受任何长度单位,能够是像素、英寸、毫米或 em。margin 能够设置为 auto。更常见的做法是为外边…

    2025年12月24日
    000
  • css怎么添加阴影效果?(代码实例)

    css怎么添加阴影效果?可以使用text-shadow属性与box-shadow属性来添加。下面本篇文章就来给大家介绍一下text-shadow属性与box-shadow属性是如何添加阴影效果的,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 推荐手册:CSS3最新版参考手册 一:添…

    2025年12月24日
    000
  • css怎么让图片自适应?css图片自适应大小的方法介绍

    对于一个网页来说,有一张好看又清晰的背景图片是非常吸引人的,但是并不是每张图片都是有相同的大小,所以就需要晒西安图片的自适应,那么,css怎么让图片自适应呢?本篇文章将来介绍关于css图片自适应大小的方法。 我们下面就来直接看一个例子: #web_bg{ position:fixed; top: 0…

    好文分享 2025年12月24日
    000
  • 分享CSS按钮的多种制作方式,附CSS 按钮样式代码

    在项目中,几乎所有的网站都会用到按钮,多则十几个,少则几个。一个实用又好看的按钮,能给页面增色不少,从而更能吸引用户的眼球。本文主要讲述css按钮的多种写法和css按钮的美化,最后会展示一款常见的css按钮样式代码,供参考。好,继续往下看吧! 一、CSS按钮的多种写法 CSS按钮可以用button直…

    2025年12月24日
    000
  • css自定义属性和聚光灯效果的实现(代码)

    本篇文章给大家带来的内容是关于css自定义属性和聚光灯效果的实现(代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 简介 CSS Variables,一个并不是那么新的东西,但对css来说绝对是一场革命。 之前使用变量的时候,需要借助sass、less等预处理工具来实现,现在我…

    2025年12月24日 好文分享
    000
  • css的overflow属性如何定义滚动条

    滚动条在网页中经常见到,却并没有受到足够的重视。只有当因为滚动条的问题需要处理兼容性时,才进行调试操作。本章就给大家带来css滚动条的常见内容。 一:条件      滚动条和overflow是紧密相关的。只有当父级的overflow的值是auto或scroll,并且元素的内容超出元素区域时,才有可能…

    2025年12月24日 好文分享
    000
  • 用纯CSS实现鼠标经过后出现下拉菜单,实例讲解(附代码)

    随便打开网上的任何一个网站,你会发现这些网站都有导航部分,而且有些导航在鼠标经过后,会出现下拉菜单,那这种下拉菜单怎么做呢?其实,用纯css就可以做导航下拉菜单。接下来,就和大家聊聊css怎么做下拉菜单,好,进入正题。 HTML 部分:1、我们可以使用任何的 HTML 元素来打开下拉菜单,如:或 a…

    2025年12月24日
    000
  • css如何分辨伪类和伪元素?伪类和伪元素的各自的区别与用法(代码实例)

    在我们学习前端开发的时候,有时总会把css中的伪类和伪元素混淆在一起。那么,在css中什么是伪类?什么又是伪元素?它们有什么区别,又是怎么使用的?本章我们就给大家好好聊聊css中的伪类和伪元素,介绍css中的伪类和伪元素的区别和基本用法。有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。…

    2025年12月24日 好文分享
    000
  • css的外间距如何设置?css外间距的设置方法(附实例)

    css盒模型中有四种元素,分别是内间距、外间距、内容还有边框。这四种定义了盒模型的使用,今天我们就来说说关于css盒模型的外间距的使用吧 css的外间距如何设置? 我们的外间距是属于css盒模型之中的一种,那么现在我们来看看外间距都是怎么设置的吧。 margin: 是一个简写属性,可以一个声明中设置…

    2025年12月24日 好文分享
    000
  • css水平居中怎么设置?两种css水平居中的设置方法

    css样式能够实现水平居中,那么css水平居中怎么设置呢?本篇文章将给大家来分享关于css设置水平居中的实现方法。 css中可以设置行内元素的水平居中和设置块级元素的水平居中,对于行内元素和块级元素不了解的同学可以参考一下css块级元素的定义是什么?css块级元素有哪些?和css行内元素有哪些?cs…

    好文分享 2025年12月24日
    000
  • css自适应布局:css宽度自适应如何实现?

    如今的网页布局是需要适应于各种屏幕的,因此就需要来实现自适应使得网页中的内容来完全的显示,所以,今天的这篇文章就来给大家介绍一下关于css宽度自适应的内容。详细的说一说css自适应布局中css宽度自适应该如何实现。 相关文章推荐:1.css高度自适应如何实现?css高度根据内容自适应的简单方法 2.…

    好文分享 2025年12月24日
    000
  • css高度自适应如何实现?css高度根据内容自适应的简单方法

    在进行网页开发时,可能会遇到这样的情况,网页中的内容会超出你原先设置的高度或者宽度,这时就需要实现高度自适应或者宽度自适应,下面这篇文章将给大家来介绍关于css高度自适应。 PS:css宽度自适应的介绍内容,可以看这篇文章:css自适应布局:css宽度自适应如何实现? 首先,我们刚开始设计某些网页板…

    2025年12月24日 好文分享
    000
  • css如何设置边框样式?边框的不同样式介绍(代码实例)

    本章给大家带来css如何设置边框样式?边框的不同样式介绍(代码实例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 一:border边框线的基本样式 边框样式属性指定要显示什么样的边界 1.border-style 属性    none: 默认无边框    dotted: 定义一个…

    2025年12月24日 好文分享
    000
  • 解决浏览器兼容性的小技巧

    当我们在进行前端网页开发,编写页面的css样式的时候,往往是需要考虑的不同浏览器的兼容问题的,让我们设计开发的前端页面可以在不同的浏览器上都可以正常展示。本章我们就给大家带来一些解决浏览器兼容性的小技巧,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 一、chrome下会让小于12p…

    好文分享 2025年12月24日
    000
  • 让css的权重变得更友好的小技巧

    在这篇文章中,我将通过一些示例来向大家展示一些css的小技巧,让你知道如何使用css的级联(cascade)能变得更友好,也减少一些不必要的需求,从而也减少权重上遇到的麻烦。 技巧一:样式总是作为特定属性组合出现 一个很好的例子就是color和bakground-color的组合。除非你只做小调整,…

    2025年12月24日
    000
  • CSS让前端网页布局更好的实用小技巧

    对css前端网页布局的技巧,可谓是名目繁多。这里将适合新手的css前端网页布局的小技巧总结出来,或许对您更有实际的参考价值: 1、ul标签在Mozilla中默认是有padding值的,而在IE中只有margin有值。 2、同一个的class选择符可以在一个文档中重复出现,而id选择符却只能出现一次;…

    好文分享 2025年12月24日
    000

发表回复

登录后才能评论
关注微信