美文网首页
复制到剪贴板功能

复制到剪贴板功能

作者: kayleeWei | 来源:发表于2018-11-14 16:50 被阅读0次

使用execCommand复制到剪贴板 必须先有input之类的元素 可以focus,select,所以思路是先创建了一个textarea元素 把需要复制的内容放进textarea 把边框等都设成0,调用execCommand,然后remove textarea。

    copyToClipboard(text) {
      var textArea = document.createElement("textarea");
      //
      // *** This styling is an extra step which is likely not required. ***
      //
      // Why is it here? To ensure:
      // 1. the element is able to have focus and selection.
      // 2. if element was to flash render it has minimal visual impact.
      // 3. less flakyness with selection and copying which **might** occur if
      //    the textarea element is not visible.
      //
      // The likelihood is the element won't even render, not even a flash,
      // so some of these are just precautions. However in IE the element
      // is visible whilst the popup box asking the user for permission for
      // the web page to copy to the clipboard.
      //

      // Place in top-left corner of screen regardless of scroll position.
      textArea.style.position = 'fixed';
      textArea.style.top = 0;
      textArea.style.left = 0;

      // Ensure it has a small width and height. Setting to 1px / 1em
      // doesn't work as this gives a negative w/h on some browsers.
      textArea.style.width = '2em';
      textArea.style.height = '2em';

      // We don't need padding, reducing the size if it does flash render.
      textArea.style.padding = 0;

      // Clean up any borders.
      textArea.style.border = 'none';
      textArea.style.outline = 'none';
      textArea.style.boxShadow = 'none';

      // Avoid flash of white box if rendered for any reason.
      textArea.style.background = 'transparent';

      textArea.value = text;

      document.body.appendChild(textArea);
      textArea.focus();
      textArea.select();

      try {
        var successful = document.execCommand('copy');
        var msg = successful ? 'successful' : 'unsuccessful';
        console.log('Copying text command was ' + msg);
      } catch (err) {
        console.log('Oops, unable to copy');
      }

      document.body.removeChild(textArea);
    }

相关文章

  • 快捷键记忆

    ipython/jupyter %paste: 将剪贴板内容复制到ipython中%cpaste: 开启复制功能,...

  • pbpaste和pbcopy

    pbpaste把剪贴板的内容复制到命令行 pbcopy把输出复制到剪贴板

  • 复制到剪贴板功能

    使用execCommand复制到剪贴板 必须先有input之类的元素 可以focus,select,所以思路是先创...

  • 复制文本到系统剪贴板

    [SVProgressHUD showSuccessWithStatus:@"已复制到系统剪贴板"];UIPast...

  • iOS开发之复制字符串到剪贴板

    这次需求有复制功能,把字符串复制到系统剪贴板, 1.在 View 里贴上scrollView2.在scrollVi...

  • vue-clipboard2实现复制功能

    在Vue中通过该模块能够实现 将内容复制到剪贴板的功能 安装 在main.js中注册 使用 vue-clipboa...

  • 复制到剪贴板

    // 复制到剪贴板export const copyText = (value) => {return new P...

  • Vue 实现复制到剪贴板功能

    项目中需要实现复制到剪贴板的功能,看了一下vue相关的插件,发现了vue-clipboard2[https://g...

  • 复制到粘贴板

    原文出处:复制到粘贴板 这是一个简单的小知识,本周我做了一个简单的“复制到剪贴板”按钮,这是我第一次做这种功能,向...

  • Javascript复制功能

    最近需要使用到Javascript的复制功能。 查询资料,总结如下内容: 有三种主要的浏览器API可复制到剪贴板 ...

网友评论

      本文标题:复制到剪贴板功能

      本文链接:https://www.haomeiwen.com/subject/fxbjfqtx.html