0

0

使用JavaScript实现一个简单的工具提示(Tooltip)组件_javascript UI组件

夜晨

夜晨

发布时间:2025-11-01 15:35:35

|

799人浏览过

|

来源于php中文网

原创

Tooltip组件通过data-tooltip属性为元素添加提示信息,使用JavaScript监听鼠标事件并动态创建、定位提示框。核心逻辑包括:利用getBoundingClientRect计算位置,确保提示框不越界,并通过append/remove控制显示与隐藏。支持多种元素且无需额外DOM嵌套,可扩展自定义位置、动画和富文本功能,轻量易集成。

使用javascript实现一个简单的工具提示(tooltip)组件_javascript ui组件

工具提示(Tooltip)是一种常见的UI组件,用于在用户悬停或聚焦某个元素时显示额外的提示信息。使用JavaScript可以轻松实现一个轻量、可复用的Tooltip组件,无需依赖第三方库。

基本结构与样式

Tooltip组件由触发元素和提示内容两部分组成。HTML结构可以非常简单:

`<button data-tooltip="这是一个提示">悬停我</button>`

使用data-tooltip属性存储提示文本,避免额外的DOM嵌套。

立即学习Java免费学习笔记(深入)”;

基础CSS样式如下,确保提示框定位准确且美观:

.tooltip {
  position: absolute;
  background: #333;
  color: #fff;
  padding: 4px 8px;
  border-radius: 4px;
  font-size: 12px;
  white-space: nowrap;
  z-index: 1000;
  pointer-events: none;
}
<p>.tooltip::after {
content: "";
position: absolute;
top: 100%;
left: 50%;
margin-left: -4px;
border: 4px solid transparent;
border-top-color: #333;
}</p>

JavaScript实现逻辑

核心功能包括:监听鼠标进入/离开事件、动态创建并定位Tooltip、以及清理资源。

以下是完整实现代码:

PPT.AI
PPT.AI

AI PPT制作工具

下载
class Tooltip {
  constructor() {
    this.tooltipEl = null;
    this.init();
  }
<p>init() {
document.body.addEventListener('mouseenter', (e) => {
const target = e.target;
const tooltipText = target.getAttribute('data-tooltip');
if (!tooltipText) return;</p><pre class='brush:php;toolbar:false;'>  this.showTooltip(target, tooltipText);
});

document.body.addEventListener('mouseleave', () => {
  this.hideTooltip();
});

}

showTooltip(element, text) { this.tooltipEl = document.createElement('div'); this.tooltipEl.className = 'tooltip'; this.tooltipEl.textContent = text; document.body.appendChild(this.tooltipEl);

this.positionTooltip(element);

}

positionTooltip(element) { const rect = element.getBoundingClientRect(); const tooltipRect = this.tooltipEl.getBoundingClientRect();

let top = rect.top - tooltipRect.height - 8;
let left = rect.left + (rect.width - tooltipRect.width) / 2;

// 简单边界检测
left = Math.max(8, Math.min(left, window.innerWidth - tooltipRect.width - 8));

if (top < 8) {
  top = rect.bottom + 8;
}

this.tooltipEl.style.top = `${top + window.scrollY}px`;
this.tooltipEl.style.left = `${left + window.scrollX}px`;

}

hideTooltip() { if (this.tooltipEl) { this.tooltipEl.remove(); this.tooltipEl = null; } } }

// 启动Tooltip new Tooltip();

使用方式

只需为任意元素添加data-tooltip属性即可启用提示功能:

<button data-tooltip="保存当前设置">保存</button>
<span data-tooltip="这是说明文字">❓</span>

支持按钮、链接、图标等多种元素,无需修改原有结构。

扩展建议

可根据需要添加以下功能:

  • 支持自定义位置(top、bottom、left、right)
  • 添加淡入淡出动画(通过CSS transition)
  • 支持富文本内容(使用data-tooltip-html
  • 延迟显示/隐藏,避免误触

基本上就这些。这个Tooltip组件简洁实用,适合集成到各种小型项目中,不复杂但能有效提升用户体验。

相关文章

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

254

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

1089

2024.03.01

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

847

2023.08.22

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

562

2023.09.20

append用法
append用法

append是一个常用的命令行工具,用于将一个文件的内容追加到另一个文件的末尾。想了解更多append用法相关内容,可以阅读本专题下面的文章。

349

2023.10.25

python中append的用法
python中append的用法

在Python中,append()是列表对象的一个方法,用于向列表末尾添加一个元素。想了解更多append的更多内容,可以阅读本专题下面的文章。

1080

2023.11.14

python中append的含义
python中append的含义

本专题整合了python中append的相关内容,阅读专题下面的文章了解更多详细内容。

186

2025.09.12

DOM是什么意思
DOM是什么意思

dom的英文全称是documentobjectmodel,表示文件对象模型,是w3c组织推荐的处理可扩展置标语言的标准编程接口;dom是html文档的内存中对象表示,它提供了使用javascript与网页交互的方式。想了解更多的相关内容,可以阅读本专题下面的文章。

4341

2024.08.14

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

25

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 42.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号