Bootstrap 5学习教程,从入门到精通,Bootstrap 5 提示框(Tooltips) 语法知识点及案例(21)

Bootstrap 5 提示框(Tooltips) 语法知识点及案例

一、提示框语法知识点

1. 基本概念

提示框(Tooltips)是当用户悬停在元素上时显示的小浮动标签,用于提供额外信息。

2. 核心属性

  • data-bs-toggle="tooltip" - 标识元素为提示框触发器
  • title - 提示框显示的内容
  • data-bs-placement - 提示框位置(top, right, bottom, left)
  • data-bs-trigger - 触发方式(hover, focus, click, manual)
  • data-bs-delay - 显示/隐藏延迟时间(毫秒)
  • data-bs-html - 是否允许HTML内容(false/true)
  • data-bs-custom-class - 自定义CSS类名
  • data-bs-offset - 提示框偏移量(像素)
  • data-bs-container - 提示框附加到的容器
  • data-bs-boundary - 提示框的溢出约束边界
  • data-bs-animation - 是否启用淡入淡出动画(true/false)
  • data-bs-template - 自定义提示框HTML模板

3. 初始化方法

必须通过JavaScript初始化提示框:

// 初始化所有提示框
var tooltipList = [].slice.call(document.querySelectorAll('[data-bs-toggle="tooltip"]'))
tooltipList.map(function (tooltipTriggerEl) {return new bootstrap.Tooltip(tooltipTriggerEl)
})// 或初始化单个提示框
var exampleEl = document.getElementById('example')
var tooltip = new bootstrap.Tooltip(exampleEl)

4. 方法

  • show() - 显示提示框
  • hide() - 隐藏提示框
  • toggle() - 切换显示/隐藏
  • dispose() - 销毁提示框
  • enable() - 启用提示框
  • disable() - 禁用提示框
  • toggleEnabled() - 切换启用/禁用状态
  • update() - 更新提示框位置

5. 事件

  • show.bs.tooltip - 显示前触发
  • shown.bs.tooltip - 显示后触发
  • hide.bs.tooltip - 隐藏前触发
  • hidden.bs.tooltip - 隐藏后触发
  • inserted.bs.tooltip - 提示框模板插入DOM后触发

二、完整案例代码

<!DOCTYPE html>
<html lang="zh-CN">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Bootstrap 5 提示框示例</title><!-- 引入Bootstrap 5 CSS --><link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/css/bootstrap.min.css" rel="stylesheet"><style>/* 自定义样式 */.custom-tooltip .tooltip-inner {background-color: #ff5722;font-size: 1.1em;}.custom-tooltip.bs-tooltip-end .tooltip-arrow::before {border-right-color: #ff5722;}.custom-tooltip.bs-tooltip-start .tooltip-arrow::before {border-left-color: #ff5722;}.custom-tooltip.bs-tooltip-top .tooltip-arrow::before {border-top-color: #ff5722;}.custom-tooltip.bs-tooltip-bottom .tooltip-arrow::before {border-bottom-color: #ff5722;}.demo-area {margin: 50px auto;padding: 20px;border: 1px dashed #ccc;border-radius: 5px;}.btn-container {display: flex;gap: 10px;flex-wrap: wrap;margin: 20px 0;}</style>
</head>
<body><div class="container"><h1 class="text-center my-5">Bootstrap 5 提示框(Tooltips)示例</h1><!-- 基本示例 --><div class="demo-area"><h3>1. 基本提示框</h3><div class="btn-container"><button type="button" class="btn btn-primary" data-bs-toggle="tooltip" title="这是默认提示框">悬停查看提示</button><button type="button" class="btn btn-secondary" data-bs-toggle="tooltip" data-bs-placement="top" title="顶部提示框">顶部提示</button><button type="button" class="btn btn-success" data-bs-toggle="tooltip" data-bs-placement="right" title="右侧提示框">右侧提示</button><button type="button" class="btn btn-danger" data-bs-toggle="tooltip" data-bs-placement="bottom" title="底部提示框">底部提示</button><button type="button" class="btn btn-warning" data-bs-toggle="tooltip" data-bs-placement="left" title="左侧提示框">左侧提示</button></div></div><!-- 触发方式 --><div class="demo-area"><h3>2. 不同触发方式</h3><div class="btn-container"><button type="button" class="btn btn-info" data-bs-toggle="tooltip" data-bs-trigger="hover" title="悬停触发(默认)">Hover触发</button><button type="button" class="btn btn-info" data-bs-toggle="tooltip" data-bs-trigger="focus" title="聚焦触发">Focus触发</button><button type="button" class="btn btn-info" data-bs-toggle="tooltip" data-bs-trigger="click" title="点击触发">Click触发</button><button type="button" class="btn btn-info" id="manual-tooltip" data-bs-toggle="tooltip" data-bs-trigger="manual" title="手动控制提示框">手动控制</button><button type="button" class="btn btn-outline-secondary" onclick="showManualTooltip()">显示提示</button><button type="button" class="btn btn-outline-secondary" onclick="hideManualTooltip()">隐藏提示</button></div></div><!-- 高级功能 --><div class="demo-area"><h3>3. 高级功能</h3><div class="btn-container"><!-- 延迟显示 --><button type="button" class="btn btn-primary" data-bs-toggle="tooltip" data-bs-delay='{"show":500, "hide":100}' title="延迟500ms显示,100ms隐藏">延迟效果</button><!-- HTML内容 --><button type="button" class="btn btn-secondary" data-bs-toggle="tooltip" data-bs-html="true" title="<em>斜体</em> <u>下划线</u> <b>加粗</b> <span class='text-danger'>红色文字</span>">HTML内容</button><!-- 自定义样式 --><button type="button" class="btn btn-success" data-bs-toggle="tooltip" data-bs-custom-class="custom-tooltip" title="自定义样式的提示框">自定义样式</button><!-- 偏移量 --><button type="button" class="btn btn-danger" data-bs-toggle="tooltip" data-bs-offset="10,20" title="偏移量x=10,y=20">偏移提示</button></div><!-- 动态内容 --><div class="mt-4"><button type="button" class="btn btn-warning" id="dynamic-tooltip" data-bs-toggle="tooltip" title="初始内容">动态更新内容</button><button type="button" class="btn btn-outline-warning" onclick="updateTooltipContent()">更新内容</button></div><!-- 禁用/启用 --><div class="mt-4"><button type="button" class="btn btn-info" id="toggle-tooltip" data-bs-toggle="tooltip" title="我可以被禁用">禁用/启用控制</button><button type="button" class="btn btn-outline-info" onclick="disableTooltip()">禁用提示</button><button type="button" class="btn btn-outline-info" onclick="enableTooltip()">启用提示</button></div></div><!-- 表单元素提示 --><div class="demo-area"><h3>4. 表单元素提示</h3><form><div class="mb-3"><label for="username" class="form-label">用户名</label><input type="text" class="form-control" id="username" data-bs-toggle="tooltip" data-bs-placement="right" title="请输入4-16位字母或数字"></div><div class="mb-3"><label for="password" class="form-label">密码</label><input type="password" class="form-control" id="password" data-bs-toggle="tooltip" data-bs-trigger="focus" data-bs-placement="bottom" title="至少8位,包含字母和数字"></div><div class="mb-3 form-check"><input type="checkbox" class="form-check-input" id="agree" data-bs-toggle="tooltip" data-bs-placement="right" title="请阅读用户协议后勾选"><label class="form-check-label" for="agree">同意条款</label></div></form></div></div><!-- 引入Bootstrap 5 JS 及其依赖 --><script src="https://cdn.jsdelivr.net/npm/@popperjs/core@2.11.6/dist/umd/popper.min.js"></script><script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/js/bootstrap.min.js"></script><script>// 页面加载完成后初始化所有提示框document.addEventListener('DOMContentLoaded', function() {// 初始化页面上的所有提示框var tooltipTriggerList = [].slice.call(document.querySelectorAll('[data-bs-toggle="tooltip"]'))tooltipTriggerList.map(function (tooltipTriggerEl) {return new bootstrap.Tooltip(tooltipTriggerEl)})// 为动态内容提示框添加事件监听var dynamicTooltip = document.getElementById('dynamic-tooltip')var dynamicTooltipInstance = bootstrap.Tooltip.getInstance(dynamicTooltip)dynamicTooltip.addEventListener('shown.bs.tooltip', function () {console.log('动态提示框已显示')})dynamicTooltip.addEventListener('hidden.bs.tooltip', function () {console.log('动态提示框已隐藏')})})// 手动控制提示框的函数function showManualTooltip() {var manualTooltip = bootstrap.Tooltip.getInstance(document.getElementById('manual-tooltip'))manualTooltip.show()}function hideManualTooltip() {var manualTooltip = bootstrap.Tooltip.getInstance(document.getElementById('manual-tooltip'))manualTooltip.hide()}// 更新提示框内容function updateTooltipContent() {var dynamicTooltip = document.getElementById('dynamic-tooltip')var dynamicTooltipInstance = bootstrap.Tooltip.getInstance(dynamicTooltip)var newContent = '更新时间: ' + new Date().toLocaleTimeString()dynamicTooltip.setAttribute('data-bs-original-title', newContent)dynamicTooltipInstance.update()}// 禁用/启用提示框function disableTooltip() {var toggleTooltip = document.getElementById('toggle-tooltip')var toggleTooltipInstance = bootstrap.Tooltip.getInstance(toggleTooltip)toggleTooltipInstance.disable()}function enableTooltip() {var toggleTooltip = document.getElementById('toggle-tooltip')var toggleTooltipInstance = bootstrap.Tooltip.getInstance(toggleTooltip)toggleTooltipInstance.enable()}</script>
</body>
</html>

三、代码说明

  1. 基本提示框:展示了不同位置的提示框(top, right, bottom, left)

  2. 触发方式

    • hover: 鼠标悬停触发(默认)
    • focus: 元素获得焦点时触发
    • click: 点击元素时触发
    • manual: 手动控制显示/隐藏
  3. 高级功能

    • 延迟显示/隐藏
    • 支持HTML内容
    • 自定义样式
    • 设置偏移量
    • 动态更新内容
    • 禁用/启用提示框
  4. 表单元素:展示了在表单输入框和复选框上使用提示框

  5. JavaScript控制

    • 手动显示/隐藏提示框
    • 动态更新提示内容
    • 禁用/启用提示功能
    • 事件监听

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

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

相关文章

设计模式实战指南:从源码解析到Java后端架构的艺术

&#x1f3af; 设计模式实战指南&#xff1a;从源码解析到Java后端架构的艺术 概述 本文档基于设计模式分类&#xff0c;详细介绍Java后端开发中各种设计模式的实际应用场景&#xff0c;结合Spring、MyBatis、Redis等主流框架的源码分析&#xff0c;帮助开发者深入理解设计模…

Python Arrow 库详解:更智能的日期时间处理

1. 安装与基本用法 安装 Arrow pip install arrow基本使用示例 import arrow# 获取当前时间 now arrow.now() print(now) # 输出: 2023-07-15T14:30:45.12345608:00# 创建特定时间 dt arrow.get(2023-07-15 14:30:00, YYYY-MM-DD HH:mm:ss) print(dt) # 输出: 2023-07-15T…

大家电破渠道困局,小家电攻用户体验,云徙有何解法?

中国家电行业正经历深刻转型。 自2018年市场规模触及8400亿顶峰后&#xff0c;行业从增量竞争转向存量博弈。与此同时&#xff0c;线上渠道在2023年首次以58%的占比超越线下&#xff0c;其中扫地机器人等小家电品类线上渗透率突破90%。消费需求也在同步重构——从家庭场景向个…

DMDPC多副本数据分布测试

需求&#xff1a;测试建表和插入数据是否会根据分布列进行自动分发。 验证方法&#xff1a;1&#xff09;准备基础环境&#xff1a;创建用户和表空间。2&#xff09;创建数据分布测试表&#xff0c;并插入数据。3&#xff09;查询指定分区数据&#xff0c;验证数据分布情况。 …

Qt/C++开发监控GB28181系统/rtp解包/jrtplib库的使用/同时支持udp和tcp被动和主动三种方式解包

一、前言说明 通过sip协议仅仅是交互&#xff0c;音视频数据的收发最终并不是通过sip传输的&#xff0c;而是通过将数据打包成rtp的格式再通过udp或者tcp通信的&#xff0c;sip协议仅仅是告知对方待会要往哪里发数据&#xff0c;是udp还是tcp。由于数据都是rtp包格式&#xff…

集群聊天服务器---muduo库的使用

使用 C 和 muduo 网络库来实现一个简单的聊天服务器和客户端。 服务器端&#xff1a; class chatServer { public:// 初始化TcpServerchatServer(muduo::net::EventLoop *loop,const muduo::net::InetAddress &listenAddr): _server(loop, listenAddr, "chatServer&…

关于Net Core Web API 项目测试 数据库模拟的两种不同方法 DC_week 6

1.关系型数据库 插件&#xff1a;Microsoft.EntityFrameworkCore.InMemory Microsoft.EntityFrameworkCore.InMemory 是一个用于测试的“临时内存数据库”&#xff0c;让你在不连接真实数据库的情况下&#xff0c;测试 EF Core 的功能。 使用时就是用具体这个框架里面已经…

如何获取 vscode 的 vsix 离线插件安装包

1、搜索所需要的插件 Extensions for Visual Studio family of products | Visual Studio Marketplace网址 2、点击 Repository 跳转到对应的 git 仓库 3、在 git 仓库依次选择 main , Tags, View all tags 4、选择你想下载的版本&#xff0c;并点击 downloads 5、往下滑动&…

ULS23 挑战:用于计算机断层扫描中 3D 通用病变分割的基准模型及基准数据集|文献速递-深度学习医疗AI最新文献

Title 题目 The ULS23 challenge: A baseline model and benchmark dataset for 3D universal lesion segmentation in computed tomography ULS23 挑战&#xff1a;用于计算机断层扫描中 3D 通用病变分割的基准模型及基准数据集 01 文献速递介绍 每年进行的CT检查数量持续…

WebSocket 端点 vs Spring Bean

在websocket端点中注入业务service时&#xff0c;不能像普通的springbean一样通过Autowired或Resource注解进行注入。主要原因是websocket端点与spring容器中的bean的生命周期管理容器不同。 WebSocket 端点&#xff08;ServerEndpoint&#xff09;和 Spring Bean 的生命周期存…

MySQL8:jdbc插入数据后获取自增ID

pom文件&#xff1a; <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation"http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"&…

MyBatis(Web后端开发第二期)

p.s.这是萌新自己自学总结的笔记&#xff0c;如果想学习得更透彻的话还是请去看大佬的讲解 目录 JDBC、数据库连接池、lombok日志输出SQL注入数据封装XML映射文件动态SQL<if><where><set><foreach><sql><include> 配置文件 Mybatis是是一…

Angular1--Hello

最近有个小错误&#xff0c;因为最近还是在看thingsboard&#xff0c;最近终于看到前端的代码&#xff0c;突然发现怎么全是ts的文件&#xff0c;仔细一看原来并不是之前认为的AngularJS&#xff0c;而是Angular。。。我tm真的无语了&#xff0c;又要去重新学。。。 Angular的…

什么是redission看门狗机制

Redisson 的看门狗机制(Watchdog Mechanism)是其实现可重入分布式锁时的一个核心特性,主要用于解决业务逻辑执行时间超过锁的过期时间(leaseTime)而导致锁提前释放,进而引发数据不一致的问题。它是一个自动的锁续期机制。 🔍 核心问题:为什么需要看门狗? 分布式锁的…

黑马程序员苍穹外卖DAY1

1. 前端页面能正常显示但无法登录&#xff08;一直转圈圈&#xff09; 找到下面路径的dev.yml port一定要跟自己本机的保持一致&#xff0c;&#xff0c;username和password也一定是自己主机的用户名和密码&#xff0c;不然连不上。 登录界面的密码为数据库表的密码&#xff0…

Frida Hook Android App 点击事件实战指南:从进程识别到成功注入

一、背景与目标 在逆向分析和自动化测试中&#xff0c;Hook Android 的点击事件是调试 UI 交互逻辑的重要手段之一。本文将以实际案例讲解如何通过 Frida Hook public void onClick(View view) 方法&#xff0c;并解决常见的 Hook 失败问题&#xff0c;最终实现对登录按钮的监…

Arduino Nano 33 BLE Sense Rev 2开发板使用指南之【环境搭建 / 点灯】

一、硬件介绍 1、产品特点 Arduino Nano 33 BLE Rev2&#xff0c;利用了nRF52840微控制器的先进功能。这款32位Arm Cortex-M4 CPU 64 MHz与MicroPython的兼容性增强了板子的灵活性&#xff0c;使其更容易被更广泛的开发者社区所接受。 该开发板的突出特点是其蓝牙低功耗&…

[QT]-宏使用

用宏,务必写清文档并用 do {…} while (0)为啥呢,示例 在 C/C++ 中,使用 do { … } while (0) 包裹宏定义是一种经典的最佳实践,主要用于解决宏展开后的语法和逻辑问题。以下是详细解释和示例: 一、为什么用 do { … } while (0) 包裹宏? 避免分号导致的语法错误 问题场…

python-property、反射

# ### property """ 可以把方法变成属性 : 可以动态的控制属性的获取,设置,删除相关操作 property 获取属性 方法名.setter 设置属性 方法名.deleter 删除属性 """ # 方法一 """是同一个方法名""" class MyCla…

【自动鼠标键盘控制器|支持图像识别】

[软件名称]: 电脑图像识别 [软件大小]: 57.2 MB [下载通道]: 夸克盘 | 迅雷盘 &#x1f3ae;【自动鼠标键盘控制器&#xff5c;支持图像识别】基于Python开发的智能自动化工具 轻量便捷的自动化操作工具&#xff0c;集成图像识别、鼠标控制、键盘模拟等功能&#xff0c;轻松…