仅使用HTML和CSS实现的标签云效果

标签云的效果在博客和网站上不难见到,它其实就是带有超链接的某些关键字,为了达到强调主题的作用。通常出现概率比较大或者受欢迎的标签文字显示比较大,相反的就显示的小。

来源于TagCrowd.com

我们就不去深入研究标签云带来的效率上的提升和可用性的细节,仅仅在外观上带来的美感和对全站或一整篇文章所起到的高度概括的作用就不容忽视了。

接下来,我们将讨论如何用HTML和CSS来创建标签云效果。注意,我们仅仅讨论如何实现这种UI效果而不去深究标签的权重或受欢迎程度是怎么算出来的。

HTML基础结构

前面说了,标签云就是一个连接列表。所以从语义化的视角,使用无序列表来表达每个标签是合理的,不用考虑按欢迎程度去排列,否则就毫无意义了。

在每个列表项里包含一个超链接标签,所以大体结构就是下面的样子:

<ul><li><a href="/tag/word1">Word1</a></li><li><a href="/tag/word2">Word2</a></li><li><a href="/tag/word3">Word3</a></li><!-- ... -->
</ul>

每个标签的权重要提前算好,然后把它加到<a>上或者<li>上,我们就暂且把它加到链接上。

权重大的标签对应显示的文字也大,代表了它的受欢迎程度大。

<ul><li><a href="/tag/word1" data-weight="3">Word1</a></li><li><a href="/tag/word2" data-weight="7">Word2</a></li><li><a href="/tag/word3" data-weight="4">Word3</a></li><!-- ... -->
</ul>

注意:这里的data-weight是通过data-count和data-total计算而来的,这里没办法直接通过两个属性计算表示,所以我们把目标聚焦在data-weight这样一个属性上。

这样基础的HTML结构代码就写好了,只要稍加一些属性就完美了。

  • class:有助于在添加样式的时候确定是哪个标签云

  • role:这个是一个导航组件,在屏幕阅读器上标识和辅助作用

  • aria-label:给辅助功能添加标题和描述

注意:如果列表位于<nav>标签内,就不需要添加role="navigation",可以使用aria-labelledby代替导航标签来指向导航标题。

让我们来完善一下列表数据,添加一些和开发相关的名词作为标签,这样看起来更贴近实际一点。

<ul class="cloud" role="navigation" aria-label="Webdev tag cloud"><li><a data-weight="4" href="/tag/http">HTTP</a></li><li><a data-weight="2" href="/tag/ember">Ember</a></li><li><a data-weight="5" href="/tag/sass">Sass</a></li><li><a data-weight="8" href="/tag/html">HTML</a></li><li><a data-weight="6" href="/tag/flexbox">FlexBox</a></li><li><a data-weight="4" href="/tag/api">API</a></li><li><a data-weight="5" href="/tag/vuejs">VueJS</a></li><li><a data-weight="6" href="/tag/grid">Grid</a></li><li><a data-weight="3" href="/tag/rest">Rest</a></li><li><a data-weight="9" href="/tag/javascript">JavaScript</a></li><li><a data-weight="3" href="/tag/animation">Animation</a></li><li><a data-weight="7" href="/tag/react">React</a></li><li><a data-weight="8" href="/tag/css">CSS</a></li><li><a data-weight="1" href="/tag/cache">Cache</a></li><li><a data-weight="3" href="/tag/less">Less</a></li>
</ul>

下面是标签云现在看起来的效果:

这是还没有添加任何样式的结果,然后给它添加一些样式

给标签云添加样式

以下是我们要通过添加样式解决的:

  • 让标签以行内元素显示

  • 让每个标签的font-size属性根据data-weight大小显示

  • 在标签的右边加上权重

  • 让标签的颜色随机显示

  • 给标签添加:hover和:focus动态样式

给ul添加样式

首先移除列表前面的小圆点和缩进

list-style: none;
padding-left: 0;

然后设置ul以Flexbox显示,并且水平垂直居中保证所有的标签元素在一行或者多行内显示

display: flex;
flex-wrap: wrap;
align-items: center;
justify-content: center;

添加上行高相互之间保持一定的垂直距离,最终的ul元素的样式如下:

ul.cloud {list-style: none;padding-left: 0;display: flex;flex-wrap: wrap;align-items: center;justify-content: center;line-height: 2.5rem;
}

然而这个时候标签云看起来还差很多

根据权重调整标签的大小

让我们开始给标签一些小的变化

ul.cloud a {color: #a33;display: block;font-size: 1.5rem;padding: 0.125rem 0.25rem;text-decoration: none;position: relative;
}

通过上面的样式,所有的标签变成淡红色并且设置1.5rem大小

然而我们的要求是字体大小根据data-weight而来的,怎么实现呢?

web标准有一种方式是CSS可以通过attr()方法读取HTML的data属性值,所以我们可以通过以下方式读取data-weight

attr([attribute-name] [attribute-unit]? [, default-value]?)

不幸的是,目前任何浏览器均不支持该表示法和功能。相反,attr()将仅返回一个字符串,并且只能在content属性中使用。

如果web标准支持这种做法,那好办,我们可以直接读取属性权重的数据,将它们保存到CSS变量中,并直接对其进行操作,如下所示:

ul.cloud a {--size: attr(data-weight number, 2); font-size: calc(var(--size) * 1rem);
}

但是这样不行,我们只能通过CSS规则,属性选择器:data-attribute

ul.cloud a[data-weight="1"] { --size: 1; }
ul.cloud a[data-weight="2"] { --size: 2; }
ul.cloud a[data-weight="3"] { --size: 3; }
ul.cloud a[data-weight="4"] { --size: 4; }
ul.cloud a[data-weight="5"] { --size: 5; }
ul.cloud a[data-weight="6"] { --size: 6; }
ul.cloud a[data-weight="7"] { --size: 7; }
ul.cloud a[data-weight="8"] { --size: 8; }
ul.cloud a[data-weight="9"] { --size: 9; }ul.cloud a {--size: 4;font-size: calc(var(--size) * 0.25rem + 0.5rem);/* ... */
}

为了避免将字体大小直接设置成权重导致太大,因此通过一定的方法计算,结果显示如下:

现在看来已经小有成就。

为标签添加权重显示

我们常见的标签云效果在标签的旁边都有权重显示,权重已经有了,我们要将它展示在伪元素::after的content中

ul.cloud[data-show-value] a::after {content: " (" attr(data-weight) ")";font-size: 1rem;
}

然后还需要给ul元素增加[data-show-value]属性选择器,将它的值设为true或者false来控制标签后面的数字权重是否显示

注意:data-show-value属性选择器的值为布尔值,即使你设置为false,它也会显示,如果不让它显示,就移除该属性

这是显示数字权重的效果

下面的案例中将不显示标签旁边的数字

为标签云添加颜色

所有的标签一个颜色看起来很沉闷,我们将尝试用两种不同的方法来为它添加不同的颜色。

使用随机生成的颜色

在CSS中没有随机数这么一说(虽然可以模拟出来)。我们将要做的是根据标签的序列号来给它定义不同的颜色,方法如下:

ul.cloud li:nth-child(2n+1) a { --color: #181; }
ul.cloud li:nth-child(3n+1) a { --color: #33a; }
ul.cloud li:nth-child(4n+1) a { --color: #c38; }

通过这种方式我们给它添加了绿色,蓝色和紫色代替了之前的淡红色,虽然也不是完全随机(有一定的规律在),但是用户很难发现。

使用同一种颜色的不同透明度值

我们通过增加标签对比度来达到强调受欢迎程度的效果,在浅色背景下,使用深色更加明显。

HSL格式的颜色值可以实现,但是我们采用最快的方式,直接对标签设置透明度,透明度的值根据权重值计算而来:

看下变化后的效果

定义它的轮廓

当我们触摸标签的时候outline样式会比较重要,尤其对于残障人士在可访问性方面。

我们将给outline添加和标签字体颜色一致的边框

ul.cloud a:focus {outline: 1px dashed;
} 

在这里我们是通过鼠标点击事件去模拟的

添加动态效果

为了增加交互性,我们为它添加一个简单的动画:当用户将鼠标移动或者悬停在一个标签上时,标签的背景色变换并且有一个水平展开的效果。

因为它是取决于状态的动画,所以我们将使用transition而不是animation动画。

实现方式是通过a标签的伪元素::before的宽度值变化,在focus和hover状态下从0变为100%来达到这样一个微交互。

CSS代码和伪元素的状态行为:

ul.cloud a::before {content: "";position: absolute;top: 0;left: 50%;width: 0;height: 100%;background: var(--color);transform: translate(-50%, 0);opacity: 0.15;transition: width 0.25s;
}ul.cloud a:focus::before,
ul.cloud a:hover::before {width: 100%;
}

对于动画效果:用户不能根据自己的喜好来开启或者关闭。如果真是一个需求的话,我们还是要尊重用户的喜好移除动画的。

可以通过媒体查询特性prefers-reduced-motion来达到
(https://developer.mozilla.org/en-US/docs/Web/CSS/@media/prefers-reduced-motion

@media (prefers-reduced-motion) {ul.cloud * {transition: none !important;}
}

好了,以上就是实现全过程,如果有哪里不懂,可以留言一起交流。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/354615.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

捍卫Java

因此&#xff0c;我们不时发布了一本电子书&#xff0c;名为“十大Java性能问题” 。 毫无例外&#xff0c;一些人回答说“问题是您正在使用Java”。 显然&#xff0c;Java一直在受到批评&#xff0c;人们已经预测了它的消亡已有一段时间了。 当然&#xff0c;它不像Python&am…

如何在客户端终止一个已经发出的HTTP请求

Javascript 异步编程得益于 Promise 的实现&#xff0c;它们极大地提高了Web开发的性能和体验。不过原生的 Promise 有个最大的缺点就是一旦请求发出去&#xff0c;我们就无法取消它。但是我们找到了另一种方法来实现。DOM 标准中添加了一个称为 AbortController 的新的控制器&…

vuex的使用二

1.先看项目的目录结构 2.在main.js里需要引入store这个文件并挂在实例上 import store from ./store/store ............new Vue({el: #app,router,store,template: <App/>,components: { App } }) 3.store.js里引入action.js和mutation.js文件 // 状态管理器 import Vue…

收到短信验证码自动填充到表单,竟然是这么玩的

苹果系统上的App和网站可以实现来自短信的验证码自动填充表单的功能&#xff0c;通常你是怎么实现这个功能的&#xff1f;有一种实现方式可能你不知道&#xff0c;单纯的HTML标签就能实现&#xff0c;不需要任何的Javascript代码该特性第一次发布是在 WWDC 2018[1]&#xff1a;…

web实现数据交互的几种常见方式

前言在当今社会&#xff0c;作为一名前端程序猿&#xff0c;并不是一昧的去制作静态页面就可以满足滴&#xff1b;你说你会制作网页&#xff0c;好吧&#xff0c;只能说你算是一个前端程序猿。但这是你作为一个程序猿最基本的能力&#xff0c;并不会为你进行加分&#xff1b; 我…

【超详细教程】如何使用TypeScript和GraphQL开发应用

GraphQL是一个专为构建灵活的API而生的强大的查询语言。它允许您为数据定义类型系统&#xff0c;因此在执行查询时&#xff0c;它仅返回所需的数据。与TypeScript一起使用时&#xff0c;GraphQL可以为开发人员提供更好的体验&#xff0c;因为它们都是类型语言。TypeScript是Jav…

jpa jsf_完整Web应用程序Tomcat JSF Primefaces JPA Hibernate –第2部分

jpa jsf托管豆 这篇文章是本教程第1部分的继续。 在“ com.mb”包中&#xff0c;您将需要创建以下类&#xff1a; package com.mb;import org.primefaces.context.RequestContext;import com.util.JSFMessageUtil;public class AbstractMB {private static final String KEEP…

洛谷 P1313 计算系数

题目描述 给定一个多项式(byax)^k&#xff0c;请求出多项式展开后x^n*y^m 项的系数。 输入输出格式 输入格式&#xff1a; 输入文件名为factor.in。 共一行&#xff0c;包含5 个整数&#xff0c;分别为 a &#xff0c;b &#xff0c;k &#xff0c;n &#xff0c;m&#xff0c;…

【利好工具】JavaScript及时运行调试工具

今天要介绍的这个工具叫RunJS[1]&#xff0c;是运行在各大系统上的客户端&#xff0c;目前支持主流的macOS、Windows、Debian和Universal Linux平台。你可以在上面编写你的JavaScript或TypeScript代码&#xff0c;并且获得即时反馈。它的左边是代码区域&#xff0c;右边是输出结…

CIFAR-10 dataset 的下载与使用

基本信息 CIFAR-10 是一个包含60000张图片的数据集。其中每张照片为32*32的彩色照片&#xff0c;每个像素点包括RGB三个数值&#xff0c;数值范围 0 ~ 255。 所有照片分属10个不同的类别&#xff0c;分别是 airplane, automobile, bird, cat, deer, dog, frog, horse, ship, tr…

教你如何创建一款属于自己的VSCode主题

你有没有想过创建一款属于自己的VSCode主题&#xff1f;没有你想像的那么难&#xff0c;但是真正实现起来也不是那么轻松&#xff0c;需要你对将要去改变的主题的一些属性要有所了解和准备。如果你要想让你的主题适用于多种编程语言&#xff0c;并且看起来还很漂亮的话&#xf…

调试

http://www.cnblogs.com/CARPE-DIEM-wu/p/7798119.html 黄金规则 从帮助台得到的观点是不明确的 检查插头 不要想,而要看 回到目录制造失败 回到目录不要想,而要看 回到目录分而治之 回到目录一次只改一个地方 回到目录保持审计跟踪 回到目录检查插头 回到目录获得全新观点 回到…

访问对象的属性,你知道有哪些方法?

相信对象对于每个使用JavaScript的人来说都不陌生。访问对象的属性几乎日常开发每天都在用。下面我们一起探索下有哪些方式可以实现属性的访问。访问对象属性介绍对象是JavaScript的一种常见的数据类型。它允许我们以键值对的形式存储数据。这一系列的键成为对象的属性。常见的…

一些行家技巧和窍门

我正在将使用WebLogic Workshop&#xff08;是的&#xff0c;使用不受支持的IDE可以正确阅读&#xff09;的现有应用程序迁移到Maven。 在旅途中有一些陷阱&#xff0c;我想在这里写下给那些可能会觉得有用并且特别适合自己的人以作为参考。 整个应用程序使用Apache XMLBeans处…

【视频内含福利】原来手机套壳视频是这么做出来的

最近视频圈子里都在发这种视频&#xff0c;究竟是怎么做出来的&#xff1f;研究下来发现原来是用的这款名字叫Record Maker的APP&#xff0c;旨在帮助用户轻松快速给视频加上手机壳的效果。目前App Store上的版本是1.2.1&#xff0c;最近一次更新支持了iPhone11/iPhone12模型&a…

机器学习 基本概念,常用经典模型

1. 机器学习 明白一些基本概念 什么是机器学习研究如何通过计算的手段&#xff0c;利用经验来改善系统自身的性能通俗来讲&#xff0c;让代码学着干活 特征&#xff1a;自变量标签&#xff1a;因变量 学习的种类有监督学习&#xff1a;提供标签&#xff0c;分类、回归无监督学习…

日常开发之重构

作为开发人员&#xff0c;应该让重构贯穿于你的开发日常的每一刻。 为什么这么说&#xff1f; 重构是为了改善软件的设计、结构和实现&#xff0c;同时保留其现有的功能。 重构的潜在优势包括提高代码的可读性和降低复杂度。 这些都可以提高源代码的可维护性&#xff0c;并创建…

摇钱树

题目描述 Cpg 正在游览一个梦中之城&#xff0c;在这个城市中有n棵摇钱树。。。这下&#xff0c;可让Cpg看傻了。。。可是Cpg只能在这个城市中呆K天&#xff0c;但是现在摇钱树已经成熟了&#xff0c;每天 每棵都会掉下不同的金币&#xff08;不属于Cpg&#xff01;&#xff09…

apache thrift_使用Java快速入门的Apache Thrift

apache thriftApache Thrift是由facebook创建的RPC框架&#xff0c;现在它是一个Apache项目。 Thrift允许您在不依赖语言的定义文件中定义数据类型和服务接口。 该定义文件用作编译器的输入&#xff0c;以生成用于构建通过不同编程语言进行通信的RPC客户端和服务器的代码。 您也…

前端八大灵感设计,代码变为现实

我们都知道掌握编程技术是一项很难的事情&#xff0c;没有捷径可走。需要我们在日复一日的工作中去锻炼。如果想要达到擅长甚至需要长年累月的积累。下面列举了一些可以给你带来编码灵感的例子&#xff0c;相信你看到会有想去写代码的冲动。因为一个好的工程师&#xff0c;是不…