当前位置: 首页 > news >正文

鼠标悬停后出现小提示框实现方法

大家在网页上会经常看到某些图标或文字,当鼠标悬停后会在四周某个位置出现一个简短的文字提示,这种提示分为两种,一种是提示固定的文字,例如放在qq图标上,会显示固定的文字“QQ”;第二种是显示鼠标所在标签的完整文字叙述,例如放在标签:“床前明月光,疑是...”,鼠标悬停后会显示完整诗句:“床前明月光,疑是地上霜”。本文就来讲述如何实现上述两种提示方法。

一、提示固定词语

这种提示因为是固定提示词,所以比较简单,使用伪类+伪元素来实现即可,代码如下:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>/* 清除页面内外边距 */*{padding: 0;margin: 0;}/* 给鼠标需要悬停的元素添加相对定位,方便调整提示词的位置 */.one{position: relative;}/* 使用伪类:hover和伪元素::before */.one:hover::before{content: "提示";/* 固定的提示词,案例数据,开发过程中按照实际情况调整 */position: absolute;/*设置绝对定位,方便调整提示词位置*/top: 30px;/* 距离父标签上方偏移量,案例数据,开发过程中按照实际情况调整 */left: 30px;/* 距离父标签左方偏移量,案例数据,开发过程中按照实际情况调整 */background-color: rgba(0,0,0,.8);/* 背景颜色,案例数据,开发过程中按照实际情况调整 */color: white;/* 文字颜色,案例数据,开发过程中按照实际情况调整 */}</style>
</head>
<body><div class="one">悬停出现提示词</div>
</body>
</html>

 结果如图所示:

二、提示词为标签内文字

第一种方法:和上述提示固定文字做法相同,只需要将伪元素里的content设置为标签内内容就行。

该方法优点是使用比较方便,缺点是只能提示固定词语。

第二种方法:只需要略微修改上方代码就行,代码如下(注释部分为发生变化的地方)

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>*{padding: 0;margin: 0;}.one{position: relative;}.one:hover::before{content: attr(title);/* 使用attr获取标签的属性内容 */position: absolute;top: 30px;left: 30px;background-color: rgba(0,0,0,.8);color: white;}</style>
</head>
<body><!-- 给标签添加一个属性,属性值为标签的内容 --><div class="one" title="提示框">悬停出现提示词</div>
</body>
</html>

该方法缺点是需要自定义一个属性并且在框架中,不同组件中的标签都需要单独写一个,优点是:可以在提示框中提示任意提示词,也可适用于vue,react等框架。

为了优化上述方法,大家也可以自行封装一个鼠标悬停后提示相应词的组件来优化代码。

http://www.lryc.cn/news/476174.html

相关文章:

  • 计算机视觉常用数据集Foggy Cityscapes的介绍、下载、转为YOLO格式进行训练
  • css中的样式穿透
  • MMCA:多模态动态权重更新,视觉定位新SOTA | ACM MM‘24 Oral
  • linux同步执行命令脚本 (xcall)
  • opencv - py_imgproc - py_grabcut GrabCut 算法提取前景
  • ChatGPT多模态命名实体识别
  • 04-Dubbo的通信协议
  • 开源数据库 - mysql - innodb源码阅读 - 线程启动
  • 在美团外卖上抢券 Python来实现
  • 【ONLYOFFICE 文档 8.2 版本深度测评】功能革新与用户体验的双重飞跃
  • npm入门教程18:npm发布npm包
  • VueSSR详解 VueServerRenderer Nutx
  • 构建您自己的 RAG 应用程序:使用 Ollama、Python 和 ChromaDB 在本地设置 LLM 的分步指南
  • 谷歌浏览器安装axure插件
  • Java唯一键实现方案
  • opencv - py_imgproc - py_canny Canny边缘检测
  • Spring Boot 创建项目详细介绍
  • 70B的模型需要多少张A10的卡可以部署成功,如果使用vLLM
  • clickhouse配置用户角色与权限
  • 面试题整理 4
  • React基础大全
  • 51c大模型~合集10
  • 【已解决】element-plus配置主题色后,sass兼容问题。set-color-mix-level() is...in Dart Sass 3
  • JavaWeb——Web入门(4/9)-HTTP协议:请求协议(请求行、请求头、请求体、演示 )
  • 软考:数据库考点总结
  • Flash的语音ic型号有哪些?
  • 10天进阶webpack---(1)为什么要有webpack
  • HTML CSS
  • 第03章 MySQL的简单使用命令
  • 【C++动态规划】2435. 矩阵中和能被 K 整除的路径|1951