使用HTML和CSS实现的标签云效果(附demo)


Posted in HTML / CSS onFebruary 03, 2021

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

使用HTML和CSS实现的标签云效果(附demo) 

来源于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>

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

使用HTML和CSS实现的标签云效果(附demo)

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

给标签云添加样式

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

  • 让标签以行内元素显示
  • 让每个标签的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;
}

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

使用HTML和CSS实现的标签云效果(附demo) 

根据权重调整标签的大小

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

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

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

使用HTML和CSS实现的标签云效果(附demo)

然而我们的要求是字体大小根据 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);
  /* ... */
}

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

使用HTML和CSS实现的标签云效果(附demo)

现在看来已经小有成就。

为标签添加权重显示

我们常见的标签云效果在标签的旁边都有权重显示,权重已经有了,我们要将它展示在伪元素 ::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,它也会显示,如果不让它显示,就移除该属性

这是显示数字权重的效果

使用HTML和CSS实现的标签云效果(附demo)

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

为标签云添加颜色

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

使用随机生成的颜色

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

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

使用HTML和CSS实现的标签云效果(附demo) 

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

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

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

看下变化后的效果

使用HTML和CSS实现的标签云效果(附demo) 

定义它的轮廓

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

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

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

使用HTML和CSS实现的标签云效果(附demo)

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

添加动态效果

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

因为它是取决于状态的动画,所以我们将使用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%;
}

使用HTML和CSS实现的标签云效果(附demo)

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

可以通过媒体查询特性 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;
  }
}

到此这篇关于使用HTML和CSS实现的标签云效果(附demo)的文章就介绍到这了,更多相关HTML和CSS标签云内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木!

HTML / CSS 相关文章推荐
CSS3对图片照片进行边缘模糊处理的实现
Aug 08 HTML / CSS
7款设计巧妙的css3飘带状3D立体效果的导航菜单和表单窗口
Feb 04 HTML / CSS
CSS3 Media Queries(响应式布局可以让你定制不同的分辨率和设备)
Jun 06 HTML / CSS
纯css3实现图片翻牌特效
Mar 10 HTML / CSS
浅析CSS3中鲜为人知的属性:-webkit-tap-highlight-color
Jan 12 HTML / CSS
CSS3制作轮播图的一种方法
Nov 11 HTML / CSS
HTML5中FileReader接口使用方法实例详解
Aug 26 HTML / CSS
HTML5等待加载动画效果
Jul 27 HTML / CSS
仿酷狗html5手机音乐播放器主要部分代码
May 15 HTML / CSS
HTML5几个设计和修改的页面范例分享
Sep 29 HTML / CSS
css3 利用transform-origin 实现圆点分布在大圆上布局及旋转特效
Apr 29 HTML / CSS
六个好看实用的 HTML + CSS 后台登录入口页面
Apr 28 HTML / CSS
canvas版人体时钟的实现示例
Jan 29 #HTML / CSS
h5页面背景图很长要有滚动条滑动效果的实现
Jan 27 #HTML / CSS
ivx平台开发之不用代码实现一个九宫格抽奖功能
Jan 27 #HTML / CSS
详解如何将 Canvas 绘制过程转为视频
Jan 25 #HTML / CSS
HTML5适合的情人节礼物有纪念日期功能
Jan 25 #HTML / CSS
html table呈现个人简历以及单元格宽度失效的问题解决
Jan 22 #HTML / CSS
浅析HTML5页面元素及属性
Jan 20 #HTML / CSS
You might like
使用 php4 加速 web 传输
2006/10/09 PHP
简单的php数据库操作类代码(增,删,改,查)
2013/04/08 PHP
PHP实现对站点内容外部链接的过滤方法
2014/09/10 PHP
thinkphp框架下404页面设置 仅三步
2016/05/14 PHP
用php和jQuery来实现“顶”和“踩”的投票功能
2016/10/13 PHP
yii2.0整合阿里云oss上传单个文件的示例
2017/09/19 PHP
JS动态添加option和删除option(附实例代码)
2013/04/01 Javascript
jquery仿苹果的时间/日期选择效果
2017/03/08 Javascript
JS+H5 Canvas实现时钟效果
2018/07/20 Javascript
Vue 路由切换时页面内容没有重新加载的解决方法
2018/09/01 Javascript
jQuery实现表格的增、删、改操作示例
2019/01/27 jQuery
深入了解js原型模式
2019/05/30 Javascript
解决微信浏览器缓存站点入口文件(IIS部署Vue项目)
2019/06/17 Javascript
javascript实现摄像头拍照预览
2019/09/30 Javascript
Python实现多线程下载文件的代码实例
2014/06/01 Python
Zookeeper接口kazoo实例解析
2018/01/22 Python
tensorflow学习笔记之mnist的卷积神经网络实例
2018/04/15 Python
Tensorflow使用支持向量机拟合线性回归
2018/09/07 Python
Python设置matplotlib.plot的坐标轴刻度间隔以及刻度范围
2019/06/25 Python
处理Selenium3+python3定位鼠标悬停才显示的元素
2019/07/31 Python
PyTorch之图像和Tensor填充的实例
2019/08/18 Python
Pycharm使用远程linux服务器conda/python环境在本地运行的方法(图解))
2019/12/09 Python
Python标准库json模块和pickle模块使用详解
2020/03/10 Python
Python 实现自动登录+点击+滑动验证功能
2020/06/10 Python
CSS3实现多样的边框效果
2018/05/04 HTML / CSS
美国精品家居用品网站:US-Mattress
2016/08/24 全球购物
法国珠宝店:CLEOR
2017/01/29 全球购物
结构和类有什么异同
2012/07/16 面试题
详解如何解决使用JSON.stringify时遇到的循环引用问题
2021/03/23 Javascript
预备党员入党思想汇报
2014/01/04 职场文书
银行求职信模板
2015/03/20 职场文书
大国崛起观后感
2015/06/02 职场文书
奖学金申请个人主要事迹材料
2015/11/04 职场文书
人民币使用说明书
2019/04/17 职场文书
导游词之云南省玉龙雪山
2019/12/19 职场文书
python单向链表实例详解
2022/05/25 Python