useCopyToClipboard

将文本复制到用户的剪贴板。

useCopyToClipboard 封装了 Clipboard API,提供一个方便的元组,包含最后复制的文本和 copy 函数。这是 useClipboard 的直接替代别名,你可以根据代码库的命名约定选择使用哪一个。更多细节请参见 useClipboard

使用场景

  • 当你偏好 useCopyToClipboard 命名约定时,添加”复制到剪贴板”功能
  • 从使用此命名模式的其他 hook 库迁移
  • 任何适用 useClipboard 的场景——两个 hook 可以互换使用

注意事项

  • SSR 安全:在服务端渲染期间返回空字符串和空操作函数。服务端不会访问 navigator
  • 浏览器支持:需要 Clipboard API(所有现代浏览器均支持)。
  • 权限:部分浏览器需要用户授权才能访问剪贴板。可配合 usePermission 检查 clipboard-readclipboard-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> | 写入&nbsp;
        <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>]: 返回只读元组.

Arguments