useCopyToClipboard
将文本复制到用户的剪贴板。
useCopyToClipboard 封装了 Clipboard API,提供一个方便的元组,包含最后复制的文本和 copy 函数。这是 useClipboard 的直接替代别名,你可以根据代码库的命名约定选择使用哪一个。更多细节请参见 useClipboard。
使用场景
- 当你偏好
useCopyToClipboard命名约定时,添加”复制到剪贴板”功能 - 从使用此命名模式的其他 hook 库迁移
- 任何适用
useClipboard的场景——两个 hook 可以互换使用
注意事项
- SSR 安全:在服务端渲染期间返回空字符串和空操作函数。服务端不会访问
navigator。 - 浏览器支持:需要 Clipboard API(所有现代浏览器均支持)。
- 权限:部分浏览器需要用户授权才能访问剪贴板。可配合
usePermission检查clipboard-read和clipboard-write的状态。
用法
Live Editor
function Demo() { const [value, setValue] = useState(""); const [text, copy] = useCopyToClipboard(); const permissionRead = usePermission("clipboard-read"); const permissionWrite = usePermission("clipboard-write"); return ( <div> <p> 剪贴板权限: 读取 <b>{permissionRead}</b> | 写入 <b>{permissionWrite}</b> </p> <p> 当前复制的内容: <code>{text || "无"}</code> </p> <input value={value} onChange={(event) => { setValue(event.currentTarget.value); }} /> <button onClick={() => copy(value)}>复制</button> </div> ); };
Result
API
useClipBoard
Returns
readonly [string, (txt: string) => Promise<void>]: 返回只读元组.