当前位置:  开发笔记 > 编程语言 > 正文

使用FireFox,Safari和Chrome将文本复制/放入剪贴板

如何解决《使用FireFox,Safari和Chrome将文本复制/放入剪贴板》经验,为你挑选了7个好方法。

在Internet Explorer中,我可以使用clipboardData对象来访问剪贴板.我怎样才能在FireFox,Safari和/或Chrome中执行此操作?



1> ine..:

出于安全考虑,Firefox不允许您在剪贴板上放置文本.但是,可以使用Flash进行解决方案.

function copyIntoClipboard(text) {

    var flashId = 'flashId-HKxmj5';

    /* Replace this with your clipboard.swf location */
    var clipboardSWF = 'http://appengine.bravo9.com/copy-into-clipboard/clipboard.swf';

    if(!document.getElementById(flashId)) {
        var div = document.createElement('div');
        div.id = flashId;
        document.body.appendChild(div);
    }
    document.getElementById(flashId).innerHTML = '';
    var content = '';
    document.getElementById(flashId).innerHTML = content;
}

唯一的缺点是这需要启用Flash.

来源目前已经死亡:http://bravo9.com/journal/copying-text-into-the-clipboard-with-javascript-in-firefox-safari-ie-opera-292559a2-cc6c-4ebf-9724-d23e8bc5ad8a/(这是谷歌缓存)


第三个缺点是它不会在不改变flash权限的情况下在本地(file://)工作.http://code.google.com/p/zeroclipboard/是围绕此方法构建的库.
截至2014年,此方法不再适用于任何现代浏览器.[ZeroClipboard](http://zeroclipboard.org/)是目前解决此问题的唯一技术

2> 小智..:

现在有一种方法可以在大多数现代浏览器中轻松使用

document.execCommand('copy');

这将复制当前选定的文本.您可以使用选择textArea或输入字段

document.getElementById('myText').select();

要隐形复制文本,您可以快速生成textArea,修改框中的文本,选择它,复制它,然后删除textArea.在大多数情况下,此textArea甚至不会闪烁到屏幕上.

出于安全原因,浏览器只允许您在用户采取某种操作(即单击按钮)时进行复制.一种方法是将onClick事件添加到调用复制文本的方法的html按钮.

一个完整的例子看起来像

function copier(){
  document.getElementById('myText').select();
  document.execCommand('copy');
}



3> agsamek..:

在线电子表格挂钩Ctrl + C,Ctrl + V事件并将焦点转移到隐藏的TextArea控件,并将其内容设置为所需的新剪贴板内容以进行复制,或在事件完成粘贴后读取其内容.

另请参阅使用Javascript在Firefox,Safari和Chrome中读取剪贴板吗?



4> a coder..:

这是2015年夏天,围绕Flash发生如此多的动荡,我想我会为这个问题添加一个新的答案,完全避免使用它.

clipboard.js是一个很好的实用程序,允许将文本或html数据复制到剪贴板.它非常容易使用,只需包含.js并使用以下内容:




clipboard.js也在GitHub上



5> Chad Scira..:

在2017年你可以做到这一点(说这个,因为这个线程已经快9岁了!)

function copyStringToClipboard (string) {
    function handler (event){
        event.clipboardData.setData('text/plain', string);
        event.preventDefault();
        document.removeEventListener('copy', handler, true);
    }

    document.addEventListener('copy', handler, true);
    document.execCommand('copy');
}

现在要复制 copyStringToClipboard('Hello World')

如果您注意到该setData行,并想知道您是否可以设置不同的数据类型,答案是肯定的.



6> Troels Thoms..:

Firefox允许您将数据存储在剪贴板中,但由于安全隐患,默认情况下会禁用它.在Mozilla Firefox知识库中的"授予JavaScript对剪贴板的访问权限"中了解如何启用它.

amdfan提供的解决方案是最好的,如果你有很多用户并且不能选择配置他们的浏览器.虽然您可以测试剪贴板是否可用并提供更改设置的链接,但用户是否精通技术.JavaScript编辑器TinyMCE遵循这种方法.



7> Andomar..:

copyIntoClipboard()函数适用于Flash 9,但它似乎被Flash播放器10的版本打破了.这是一个可以与新的Flash播放器配合使用的解决方案:

http://bowser.macminicolo.net/~jhuckaby/zeroclipboard/

这是一个复杂的解决方案,但确实有效.


它没有破碎.出于安全原因,它已从最新的API中删除
推荐阅读
ifx0448363
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有