<Spoiler />组件受Telegram剧透功能启发,spoiled渲染一个动画粒子云覆盖文本、内联或块级元素,将其隐藏直到被揭示。
prefers-reduced-motion;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元素中所有标准属性都被代理到底层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在元素离开视口时停止动画。
你还可以使用fps和density属性控制性能:
// 默认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%浏览器的支持(我们确实有备用方案!)。当用于大块文本时,动画可能不流畅且性能不佳。
此外,我们不保证秘密会保持隐藏。使用风险自负。


AI赋能电商视觉革命,一站式智能商拍平台
潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率,让品牌能够快速上架。


企业专属的AI法律顾问
iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。


稳定高效的流量提升解决方案,助力品牌曝光
稳定高效的流量提升解决方案,助力品牌曝光


最新版Sora2模型免费使用,一键生成无水印视频
最新版Sora2模型免费使用,一键生成无水印视频


实时语音翻译/同声传译工具
Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。


选题、配图、成文,一站式创作,让内容运营更高效
讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。


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


最强AI数据分析助手
小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。


像人一样思考的AI智能体
imini 是一款超级AI智能体,能根据人类指令,自主思考、自主完成、并且交付结果的AI智能体。


AI数字人视频创作平台
Keevx 一款开箱即用的AI数字人视频创作平台,广泛适用于电商广告、企业培训与社媒宣传,让全球企业与个人创作者无需拍摄剪辑,就能快速生成多语言、高质量的专业视频。
最新AI工具、AI资讯
独家AI资源、AI项目落地

微信扫一扫关注公众号