您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

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

2024/3/10 0:54:51发布32次查看
本篇文章给大家带来的内容是如何使用css在线字体和d3实现google的信息图 ,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
效果预览
源代码下载https://github.com/comehope/front-end-daily-challenges
代码解读定义 dom,只有 1 个空元素,其中不包含任何文本:
<div class="logo"></div>
引入字体文件,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 个数字,在每个数字的内联样式中指定了颜色变量:
<p class="desc">the name of google originated from a misspelling of the word googol, the number 1 followed by 100 zeros.</p> <p class="zeros">    <span style="--c:var(--blue);">1</span>    <span style="--c:var(--red);">0</span>    <span style="--c:var(--yellow);">0</span>    <span style="--c:var(--blue);">0</span>    <span style="--c:var(--green);">0</span></p>
设置说明文本的样式:
.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 的数字子元素:
<script src="https://d3js.org/d3.v5.min.js"></script>
最终我们会在页面上显示 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 个包含 number 和 color 属性的对象:
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的信息图的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product