zoukankan      html  css  js  c++  java
  • 简单实现兼容各大浏览器的js复制内容到剪切板

    因为网站文章需要提供几个按钮,单击后实现复制文章内容到剪贴板。

    在网上搜索了很多内容,发现都比较乱这里自己整理下,分享给大家

    效果图如下:

    之前使用的是window.clipboardData.setData,只能支持IE和火狐。360浏览器、搜狗等浏览器,都泪崩。所以,研究了ZeroClipboard,尽量使用js代码写。

    使用前先引用三个东西(没有提供上传附件,这里就不提供下载地址了,很常见,大家自己找度娘吧):

    jquery-1.4.1.min.js    
    ZeroClipboard.js   
    ZeroClipboard.swf 

    下面是最简单的实现了,做一下解释。

    原理

    把一个不可见的 Adobe Flash movie元素放到一个DOM元素上。用户点击那DOM元素时,其实点击的是那不可见的Adobe Flash movie元素,Flash代码来做将内容复制到剪切板的操作。

    注意:如果用js模拟一个在那flash上的点击事件,并不能进行复制内容到剪贴板。原因是浏览器和flash的安全限制。

    a标签就是一个按钮,你可以替换成图片等,但是id要和下面的clip.glue("copy_text");一致。

    clip.setText(AddContent+ document.getElementById("id_div").innerText + AddContent);这一句的di_div就是要复制的Div的ID。这个ID可以是其他的标签的ID。想复制什么就写什么的ID。

    其他的就原样复制。你需要改的,就是最上面两行,第一行就是需要复制的标签,一般你的网页里已经有了。只要给他设置个ID即可。那么第一行可以删掉。第二行就可以自由发挥,反正用超链接也好,图片也好,只要ID和下面的一样即可。

    对于事先准备的三个文件,请上传到代码中所示的路径中。这个据说是在服务器运行才行,我直接上传服务器测试的

    这里已经是最简化的代码了。网上的那些乱七八糟的,实在不忍直视,所以,做出来就及时和大家分享一下。如果本文章有问题要问,可以在博客留言。

     下面是实现的代码:

    <div id="id_div">文本内容</div><br><a href='#' id="copy_text" title="以纯文本形式复制">复制文章纯文本内容</a><br>
    <script type="text/javascript" src="/js/global/jquery-1.4.1.min.js"></script>
    <script type="text/javascript" src="/js/global/ZeroClipboard.js"></script>
    <script type="text/javascript">
    var clip = null;
    ZeroClipboard.setMoviePath("/js/global/ZeroClipboard.swf");
    $(document).ready(function(){
        var AddContent = "
    本原创文章来源:C++技术网,阅读更多原创精品文章,欢迎访问C++技术网。
    ";
      clip = new ZeroClipboard.Client();
      clip.setHandCursor(true);
      clip.setText(AddContent+ document.getElementById("id_div").innerText + AddContent);
      clip.glue("copy_text");
      clip.addEventListener("complete", function(){
        alert("文章纯文本内容已经复制到剪切板!");
      });
    });
    </script>
    

      


  • 相关阅读:
    .NET 用 Unity 依赖注入——概述注册和解析类型(1)
    .NET 服务器定位模式(Service Locator Pattern)——Common Service Locator
    用什么样的语言就有什么样的公司【转载】
    编程语言和工具比较【翻译】
    .NET 基于任务的异步模式(Task-based Asynchronous Pattern,TAP) async await
    RocketMQ【未完成】
    Dapper
    Java 控制反转和依赖注入模式【翻译】【整理】
    Java 面向切面编程(Aspect Oriented Programming,AOP)
    Groovy 与 Python 的差异【翻译】
  • 原文地址:https://www.cnblogs.com/good10000/p/4800718.html
Copyright © 2011-2022 走看看