网站首页 > 技术文章 正文
- 介绍
Tippyjs轻量的纯 JavaScript 动态提示工具插件库。它提供了大量的不同悬停效果和超过 20 个可定制的选项。Tippy.js 是超级轻量的,具有相当不错的浏览器兼容性:
Github
//文档:https://atomiks.github.io/tippyjs/
//Github: https://github.com/atomiks/tippyjs
功能特性
Tippy.js是由Popper.js支持的高度可定制的工具提示和弹出库。
- 智能定位引擎
优化的定位引擎,可防止翻转和溢出
- 高性能
在低端设备也能够保持很高的性能
- 多功能
适用于鼠标,键盘和触摸输入
- 无障碍
兼容WAI-ARIA
- 主题化的
通过自定义CSS样式,包括额外的主题和动画
- 插件化
使用插件增强功能
- 轻量级
最小化包的大小
- Typescript的支持
开箱即用的TypeScript支持
- 支持IE11 +
与99%的台式机和97%的移动用户兼容
默认示例
它具有#333的背景色和指向该元素的箭头,并且由鼠标输入或焦点事件触发,因此它会在悬停时显示,通过键盘导航聚焦或在使用触摸设备时轻击。
<button id="myButton">My Button</button>
tippy('#myButton', {
content: "I'm a Tippy tooltip!"
});
安装
常用npm或者yarn安装使用
# npm
npm i tippy.js
# Yarn
yarn add tippy.js
import tippy from 'tippy.js';
import 'tippy.js/dist/tippy.css';
使用
- 创建tooltips
给在你想要的标签元素上添加data-tippy-content属性
<button data-tippy-content="Tooltip">Text</button>
<button data-tippy-content="Another Tooltip">Text</button>
或者
tippy('#singleElement', {
content: 'Tooltip'
});
- 自定义
tippy('button', {
duration: 0,
arrow: false,
delay: [1000, 200]
});
也可以指定特定的属性
<button
data-tippy-duration="0"
data-tippy-arrow="false"
data-tippy-delay="[1000, 200]"
>
Text
</button>
- HTML Content
内容道具可以接受字符串,元素或函数。
普通字符串:
tippy('button', {
content: '<strong>Bolded content</strong>'
});
innerHtml:
<div id="template" style="display: none;">
<strong>Bolded content</strong>
</div>
const template = document.getElementById('template');
tippy('button', {
content: template.innerHTML
});
element:
可以传递元素本身,这对于使事件侦听器保持连接状态(或在框架控制内部元素时非常有用)
const template = document.getElementById('example');
template.style.display = 'block';
tippy(singleButton, {
content: template
});
Template linking:
如果您有多个引用,每个引用都有其自己的唯一模板,则可以通过以下方式将它们链接到关联的模板:
<button data-template="one">One</button>
<button data-template="two">Two</button>
<button data-template="three">Three</button>
<div style="display: none;">
<div id="one">
<strong>Content for `one`</strong>
</div>
<div id="two">
<strong>Content for `two`</strong>
</div>
<div id="three">
<strong>Content for `three`</strong>
</div>
</div>
tippy('button', {
content(reference) {
const id = reference.getAttribute('data-template');
const template = document.getElementById(id);
return template.innerHTML;
}
});
主题Themes
可以通过CSS进行任何自定义样式,本身提供了以下几个主题可供选择
tippy('button', {
theme: 'light'
});
总结
具体的使用方式还是具体的样式,都可以直接参照官方文档,个人认为这是独立组件中非常不错的一个小组件,enjoy it!
猜你喜欢
- 2025-05-23 Dynamics.js – 创建逼真的物理动画的 JS 库
- 2025-05-23 CSS3 过渡与动画
- 2025-05-23 10个惊人的文字动画特效「值得收藏」
- 2025-05-23 Vue3 流程图组件库 :Vue Flow
- 2025-05-23 一组开源免费的Web动画图标,荐给需要的设计师和程序员
- 2025-05-23 推荐一款开箱即用的动画可视化编辑器(rean-editor)
- 2025-05-23 资源分享:异常强大的预设css3动画库Animate
- 2025-05-23 Vue3 生态:10 个最强大的动效组件库!
- 2025-05-23 实用干货:最全的Loading动画合集网站!复制即用
- 2025-05-23 一款 Js 动画库,简单几行代码就能写出丝滑流畅、高性能的动画效果
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端react (48)
- 前端aes加密 (58)
- 前端md5加密 (49)
- 前端路由 (55)
- 前端数组 (65)
- 前端定时器 (47)
- 前端接口 (46)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle 中文 (51)
- oracle链接 (47)
- oracle的函数 (57)
- mac oracle (47)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)