|
导读网页的本质就是超级文本标记语言,通过结合使用其他的Web技术(如:脚本语言、公共网关接口、组件等),可以创造出功能强大的网页。因而,超级文本标记语言是万维网(Web)编程的基础,也就是说万维网是建立... 网页的本质就是超级文本标记语言,通过结合使用其他的Web技术(如:脚本语言、公共网关接口、组件等),可以创造出功能强大的网页。因而,超级文本标记语言是万维网(Web)编程的基础,也就是说万维网是建立在超文本基础之上的。超级文本标记语言之所以称为超文本标记语言,是因为文本中包含了所谓“超级链接”点。 本篇文章给大家带来的内容是如何使用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,注意 .logo::before {
content: 'google_logo';
font-size: 10vw;
}设置字体,采用刚才引入的在线字体,刚才页面上的 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);
}微调数字 .zeros span:nth-child(1) {
margin-right: 0.2em;
}至此,静态布局完成,接下来用 d3 批量处理数字。 引入 d3 库,并删除掉 dom 中 <script src="https://d3js.org/d3.v5.min.js"></script> 最终我们会在页面上显示 100 个 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 个常量, const ZEROS = d3.range(100).map(x=>0)
const ONE = {number: 1, color: 'blue'}接下来,通过用 let numbers = ZEROS.reduce(function (numberObjects, d) {
numberObjects.push({
number: d,
color: getColor(numberObjects[numberObjects.length - 1].color)
})
return numberObjects
}, [ONE])然后,以 d3.select('.zeros')
.selectAll('span')
.data(numberObjects)
.enter()
.append('span')
.style('--c', (d)=>`var(--${d.color})`)
.text((d)=>d.number)最后,微调一下内容的边距,使整个内容居中: .logo {
margin-top: -10vh;
}大功告成! 相关推荐: CSS3文字特效属性text-shadow的介绍,实例讲解火焰文字效果以上就是如何使用CSS在线字体和D3实现Google的信息图的详细内容,更多请关注php中文网其它相关文章! 网站建设是一个广义的术语,涵盖了许多不同的技能和学科中所使用的生产和维护的网站。 |
温馨提示:喜欢本站的话,请收藏一下本站!