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

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

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

Project Cover

有言AI

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

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

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

Project Cover

讯飞文书

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

Project Cover

阿里绘蛙

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

Project Cover

AIWritePaper论文写作

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

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