前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >前端Tips#7 - 用 6 行代码实现文本复制

前端Tips#7 - 用 6 行代码实现文本复制

作者头像
JSCON简时空
发布2020-04-02 10:11:00
1.9K0
发布2020-04-02 10:11:00
举报
文章被收录于专栏:JSCON简时空

本期主要是讲一个 JS 技巧,用 6 行代码实现文本复制的功能。

视频讲解

https://v.qq.com/x/page/t09429int8j.html

音频讲解

文字讲解

代码片段

核心的代码片段就 6 行,利用动态创建 textarea,和 document.execCommand 命令就实现了:

代码语言:javascript
复制
const copyToClipboard = str => {
  const el = document.createElement('textarea');
  el.value = str;
  document.body.appendChild(el);
  el.select();
  document.execCommand('copy');
  document.body.removeChild(el);
};

替代方案

因为 document.execCommand 命令虽说还能使用,然而官方建议尽可能少用。官方比较推荐的还是 Navigator.clipboard API,当然该对象还在草案状态,IE、Safari 也还不支持,所以兼容性需要考虑。

使用 Clipboard_API 就很方便实现 复制粘贴 功能:

代码语言:javascript
复制
const copyToClipboard = async str => {
    ...
    // 写入粘贴板
    await navigator.clipboard.writeText(str)
    ...
    // 读取粘贴板
    await navigator.clipboard.readText()
};

注意事项

  • 因为浏览器安全限制,文本复制 功能必须由用户主动触发(比如放在点击事件里),而不能一进页面就自动触发
  • 建议这个代码片段只是用于 能力增强 部分,就算牺牲掉该功能也没多大关系。
  • 如果非要用于主功能里,建议使用成熟的 clipboard.js 开源库

参考文档

  • Copying text to clipboard with JavaScript:30 seconds of code
  • How to copy to the clipboard using JavaScript:使用 Clipboard_API
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-04-01,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 JSCON简时空 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 代码片段
  • 替代方案
  • 注意事项
  • 参考文档
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档