Project Icon

spoiled

React动画粒子云组件实现内容隐藏效果

Spoiled是一个React组件,通过CSS Painting API生成动画粒子云效果来隐藏文本或元素。支持多种显示模式和内容过渡动画,并可根据用户偏好调整。开发者能够控制FPS、密度和颜色等性能参数。适用于隐藏敏感内容,在不支持的浏览器上会降级为静态图像。

Spoiled演示 - 隐藏你的珍贵秘密

用于React的逼真的<Spoiler />组件

Telegram剧透功能启发,spoiled渲染一个动画粒子云覆盖文本、内联或块级元素,将其隐藏直到被揭示。

  • 使用**CSS绘制API(Houdini)实现内联元素的逼真渲染。提供静态图像备用方案**;
  • 支持浅色/深色/系统模式;
  • 动画内容过渡淡入淡出/光圈),或自定义;
  • 遵循prefers-reduced-motion
  • 控制性能:FPS密度颜色等;

CSS绘制API在Firefox和Safari中仍不受支持。 我们为这些浏览器提供静态备用图像,你可以通过fallback属性自定义。此外,还有一个可用的polyfill

如何使用?

安装包,需要React 18:

npm i spoiled

或使用你喜欢的包管理器:

pnpm add spoiled
yarn add spoiled

用剧透包裹你的文本,以保持情节转折隐藏:

import { Spoiler } from "spoiled";

// 悬停时揭示
<Spoiler>
  霍格沃茨是一个高科技<b>创业孵化器</b>
</Spoiler>;

默认情况下,剧透功能:

  • 悬停时揭示(非受控)
  • 使用系统配色方案
  • 将内容包裹在span元素中
  • 注入少量CSS用于内容过渡(请阅读下面如何选择退出)

所有标准属性都被代理到底层span元素。你也可以使用tagName属性更改标签:

<Spoiler className="custom" aria-label="完全保密">
  尼奥开设了一个数字健康retreat
</Spoiler>;

// 你也可以隐藏块级元素!
<Spoiler tagName="div">
  <img />
</Spoiler>;

隐藏和揭示剧透

<Spoiler />是非受控的,默认隐藏。使用revealOn属性来设置点击或悬停时揭示内容:

<Spoiler revealOn="click">点击我</Spoiler>;
<Spoiler revealOn="hover">悬停我</Spoiler>;

// 点击隐藏剧透
<Spoiler defaultHidden={false} revealOn="click">
  弗罗多开始了一个戒指主题的珠宝系列
</Spoiler>;

然而,我们建议传递hidden属性从你的应用控制剧透状态:

const [hidden, setHidden] = useState(true);

<Spoiler hidden={hidden} onClick={() => setHidden((s) => !s)} />;

主题

剧透适应当前的配色方案,但你也可以覆盖主题和噪点的强调色:

/**
 * 主题
 */

<Spoiler /> // 默认主题是`system`
<Spoiler theme="dark" />
<Spoiler theme="light" />

/**
 * 自定义噪点的主要颜色
 */

<Spoiler accentColor="red" />

// 使用浅色和深色颜色数组实现
// 动态强调色
<Spoiler accentColor={["black", "white"]} />

性能

Spoiled使用IntersectionObserver在元素离开视口时停止动画。 你还可以使用fpsdensity属性控制性能:

// 默认FPS是24,但16-20也应该看起来不错
<Spoiler fps={16} />

// 默认:0.12
// 控制渲染的粒子数量
// 越高,噪点越密集
<Spoiler density={0.2}>重要秘密</Spoiler>

单词形状

当应用于内联元素时,<Spoiler />会尝试模仿段落中单词的形状(伪造单词间的空格)。

由于可能不准确,使用mimicWords设置来禁用它:

<Spoiler mimicWords={false}>这将被渲染为一行实心文本</Spoiler>

样式

Spoiled会按需将一个小的<style>标签注入文档,其中包含用于隐藏和揭示过渡动画的CSS。你可以使用无样式版本,然后以不同方式加载这些样式。

import { Spoiler } from "spoiled/no-css";

// 如果你使用Vite或类似的打包工具,这些样式将被写入最终的CSS包中
import "spoiled/style.css";

免责声明

截至2024年,CSS Houdini API得到了70%浏览器的支持(我们确实有备用方案!)。当用于大块文本时,动画可能不流畅且性能不佳。

此外,我们不保证秘密会保持隐藏。使用风险自负。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

问小白

问小白是一个基于 DeepSeek R1 模型的智能对话平台,专为用户提供高效、贴心的对话体验。实时在线,支持深度思考和联网搜索。免费不限次数,帮用户写作、创作、分析和规划,各种任务随时完成!

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

Trae

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号