您现在的位置: 365建站网 > 365文章 > js/javascript/jQuery实现复制到剪贴板的方法(兼容所有浏览器)

js/javascript/jQuery实现复制到剪贴板的方法(兼容所有浏览器)

文章来源:365jz.com     点击数:2314    更新时间:2017-12-12 10:48   参与评论

一、实现点击按钮,复制文本框中的的内容

</>code

  1. <script type="text/javascript">
  2. function copyUrl2()
  3. {
  4. var Url2=document.getElementById("biao1");
  5. Url2.select(); // 选择对象
  6. document.execCommand("Copy"); // 执行浏览器复制命令
  7. alert("已复制好,可贴粘。");
  8. }
  9. </script>
  10. <textarea cols="20" rows="10" id="biao1">用户定义的代码区域</textarea>
  11. <input type="button" onClick="copyUrl2()" value="点击复制代码" />

 二、复制专题地址和 url 地址,传给 QQ/MSN 上的好友

</>code

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
  5. <title>Js复制代码</title>
  6. </head>
  7. <body>
  8. <p>
  9. <input type="button" name="anniu1" onClick='copyToClipBoard()' value="复制专题地址和url地址,传给QQ/MSN上的好友">
  10. <script language="javascript">
  11. function copyToClipBoard(){
  12. var clipBoardContent="";
  13. clipBoardContent+=document.title;
  14. clipBoardContent+="";
  15. clipBoardContent+=this.location.href;
  16. window.clipboardData.setData("Text",clipBoardContent);
  17. alert("复制成功,请粘贴到你的QQ/MSN上推荐给你的好友");
  18. }
  19. </script>

三、直接复制 url

</>code

  1. <input type="button" name="anniu2" onClick='copyUrl()' value="复制URL地址">
  2. <script language="javascript">
  3. function copyUrl()
  4. {
  5. var clipBoardContent=this.location.href;
  6. window.clipboardData.setData("Text",clipBoardContent);
  7. alert("复制成功!");
  8. }
  9. </script>

四、点击文本框时,复制文本框里面的内容

</>code

  1. <input onclick="oCopy(this)" value="你好.要copy的内容!">
  2. <script language="javascript">
  3. function oCopy(obj){
  4. obj.select();
  5. js=obj.createTextRange();
  6. js.execCommand("Copy")
  7. alert("复制成功!");
  8. }
  9. </script>

五、复制文本框或者隐藏域中的内容

</>code

  1. <script language="javascript">
  2. function CopyUrl(target){
  3. target.value=myimg.value;
  4. target.select();
  5. js=myimg.createTextRange();
  6. js.execCommand("Copy");
  7. alert("复制成功!");
  8. }
  9. function AddImg(target){
  10. target.value="[IMG]"+myimg.value+"[/ img]";
  11. target.select();
  12. js=target.createTextRange();
  13. js.execCommand("Copy");
  14. alert("复制成功!");
  15. }
  16. </script>

六、复制 span 标记中的内容

</>code

  1. <script type="text/javascript">
  2. </script>
  3. <br />
  4. <br />
  5. <script type="text/javascript">function copyText(obj)
  6. {
  7. var rng = document.body.createTextRange();
  8. rng.moveToElementText(obj);
  9. rng.scrollIntoView();
  10. rng.select();
  11. rng.execCommand("Copy");
  12. rng.collapse(false);
  13. alert("复制成功!");
  14. }
  15. </script>

七、浏览器兼容  copyToClipboard("拷贝内容")

</>code

  1. function copyToClipboard(txt) {
  2. if (window.clipboardData) {
  3. window.clipboardData.clearData();
  4. clipboardData.setData("Text", txt);
  5. alert("复制成功!");
  6. } else if (navigator.userAgent.indexOf("Opera") != -1) {
  7. window.location = txt;
  8. } else if (window.netscape) {
  9. try {
  10. netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
  11. } catch (e) {
  12. alert("被浏览器拒绝!\n请在浏览器地址栏输入'about:config'并回车\n然后将 'signed.applets.codebase_principal_support'设置为'true'");
  13. }
  14. var clip = Components.classes['@mozilla.org/widget/clipboard;1'].createInstance(Components.interfaces.nsIClipboard);
  15. if (!clip)
  16. return;
  17. var trans = Components.classes['@mozilla.org/widget/transferable;1'].createInstance(Components.interfaces.nsITransferable);
  18. if (!trans)
  19. return;
  20. trans.addDataFlavor("text/unicode");
  21. var str = new Object();
  22. var len = new Object();
  23. var str = Components.classes["@mozilla.org/supports-string;1"].createInstance(Components.interfaces.nsISupportsString);
  24. var copytext = txt;
  25. str.data = copytext;
  26. trans.setTransferData("text/unicode", str, copytext.length * 2);
  27. var clipid = Components.interfaces.nsIClipboard;
  28. if (!clip)
  29. return false;
  30. clip.setData(trans, null, clipid.kGlobalClipboard);
  31. alert("复制成功!");
  32. }
  33. }

八、兼容各大浏览器的复制代码(结合ZeroClipboard.js)

</>code

  1. <html>
  2. <head>
  3. <title>Zero Clipboard Test</title>
  4. <script type="text/javascript" src="ZeroClipboard.js"></script>
  5. <script language="JavaScript">
  6. var clip = null;
  7. function $(id) { return document.getElementById(id); }
  8. function init() {
  9. clip = new ZeroClipboard.Client();
  10. clip.setHandCursor(true);
  11. clip.addEventListener('mouseOver', function (client) {
  12. // update the text on mouse over
  13. clip.setText( $('fe_text').value );
  14. });
  15. clip.addEventListener('complete', function (client, text) {
  16. //debugstr("Copied text to clipboard: " + text );
  17. alert("该地址已经复制,你可以使用Ctrl+V 粘贴。");
  18. });
  19. clip.glue('clip_button', 'clip_container' );
  20. }
  21. </script>
  22. </head>
  23. <body onLoad="init()">
  24. <input id="fe_text" cols=50 rows=5 value=复制内容文本1 >
  25. <span id="clip_container"><span id="clip_button"><b>复制</b></span></span>
  26. </body>
  27. </html

 

实现复制到剪贴板功能,兼容所有浏览器:

目录(支持移动端ios复制

前言

今年下半年打算在组内建个叫『移动开发指南』的站点,在网站框架搭建过程,有一个功能需要实现复制文本到剪贴板,相信这个功能很常用,但是对于不常写JS代码的我来说是一个比较大的挑战,回想以前做过的一个站点,使用window.clipboardData实现复制到剪贴板功能,也仅仅支持IE和FF浏览器,当时在百度找个几个方案,看不下去就放弃了,后来在代码中做了判断,如果不支持该属性,就直接alert:此功能不支持该浏览器,请手工复制文本框中内容,现在想想真是偷懒啊,嘿嘿,有没有人中枪啊~

</>code

  1. alert("此功能不支持该浏览器,请手工复制文本框中内容");

现在网络上其实并没有比较详细讲解js实现复制到剪贴板功能,很多文章是千遍一律,对于需要使用复制到剪贴板功能的童鞋来说,是比较蛋疼的,今天给大家带来这块的分享,由于能力有限,有错误的地方还请大家多多指教~

独立的js库Zero Clipboard简单实现复制到剪贴板功能

相信很多使用wordpress搭建过站点的同学都知道它采用了jQuery,对jQuery大家并不陌生,使用起来非常简单,可惜jQuery本身并没有实现复制到剪贴板的功能,但或许它的API会有这个功能。这次我搭建的站点采用wordpress,花了点时间搜索jQuery复制到剪贴板的API,还真的有:jQuery ZeroClipboard ,于是使用它在wordpress简单实现了复制到剪贴板的功能。但是呢,jQuery ZeroClipboard原来是有个父亲大人,叫Zero Clipboard。

Zero Clipboard作为一个独立的js库,它利用 Flash 进行复制,需要两个文件:ZeroClipboard.js 和 ZeroClipboard.swf 。网络上有2个版本,实现原理都是使用flash进行复制,不知道原创是谁的,也可能一家子的2个兄弟,这个就不管了,只要我们自己做到尊重版权,表示问心无愧,今天给大家介绍的这个版本相对来说比较简单。

首先看下图是为使用Zero Clipboard后生成的flash对象,它能兼容的flash10及以下版本,兼容所有的浏览器:

Zero Clipboard的官方地址:http://zeroclipboard.org/,github地址:https://github.com/zeroclipboard/ZeroClipboard

使用它需要搭建服务器环境,可能有同学不太清楚,关于搭建服务器环境的,方法有很多,如xp或者win7系统自带的IIS,也可以使用xamppappservAPMServ等集成包,安装即可,搭建起来非常简单,这里不做介绍~

demo如下:

复制代码

</>code

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <title>Zero Clipboard Test</title>
  5. <meta charset="utf-8">
  6. </head>
  7. <body>
  8. <!--
  9. 说明:
  10. 1.data-clipboard-target 输入要复制的对象的ID
  11. -->
  12. <button id="d_clip_button" class="my_clip_button" data-clipboard-target="fe_text"><b>复制到剪贴板</b></button>
  13. <br/>
  14. <textarea id="fe_text" cols="50" rows="3">输入需要复制的内容</textarea>
  15. </body>
  16. </html>
  17. <script type="text/javascript" src="ZeroClipboard.js"></script>
  18. <script type="text/javascript">
  19. // 定义一个新的复制对象
  20. var clip = new ZeroClipboard( document.getElementById("d_clip_button"), {
  21. moviePath: "ZeroClipboard.swf"
  22. } );
  23. // 复制内容到剪贴板成功后的操作
  24. clip.on( 'complete', function(client, args) {
  25. alert("复制成功,复制内容为:"+ args.text);
  26. } );
  27. </script>
复制代码

demo下载 (温馨提示:下载代码的同学,浏览demo时记得使用服务器环境,不然看不到效果的~)

上面代码注释中已经对Zero Clipboard的功能进行了介绍,需要了解更多的功能请到https://github.com/zeroclipboard/ZeroClipboard

 jQuery ZeroClipboard实现复制到剪贴板功能

jQuery ZeroClipboard是在ZeroClipboard的基础上进行的改良,简称zClip,作为jQuery的API,jQuery ZeroClipboard也表现的非常简易操作,官方地址:http://www.steamdev.com/zclip/

使用前需引用2个js文件:jquery.js和jquery.zclip.js

</>code

  1. <script type="text/javascript" src="js/jquery.js"></script>
  2. <script type="text/javascript" src="js/jquery.zclip.js"></script>

现在我们使用jquery.zclip.js简单实现复制到剪贴板功能demo如下:

复制代码

</>code

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <title>ZeroClipboard Test</title>
  5. <meta charset="utf-8">
  6. <style type="text/css">
  7. .line{margin-bottom:20px;}
  8. /* 复制提示 */
  9. .copy-tips{position:fixed;z-index:999;bottom:50%;left:50%;margin:0 0 -20px -80px;background-color:rgba(0, 0, 0, 0.2);filter:progid:DXImageTransform.Microsoft.Gradient(startColorstr=#30000000, endColorstr=#30000000);padding:6px;}
  10. .copy-tips-wrap{padding:10px 20px;text-align:center;border:1px solid #F4D9A6;background-color:#FFFDEE;font-size:14px;}
  11. </style>
  12. <script type="text/javascript" src="jquery.js"></script>
  13. <script type="text/javascript" src="jquery.zclip.js"></script>
  14. </head>
  15. <body>
  16. <div class="line">
  17. <h2>demo1 点击复制当前文本</h2>
  18. <a href="#none" class="copy">点击复制我</a>
  19. </div>
  20. <div class="line">
  21. <h2>demo2 点击复制表单中的文本</h2>
  22. <a href="#none" class="copy-input">点击复制单中的文本</a>
  23. <input type="text" class="input" value="输入要复制的内容" />
  24. </div>
  25. </body>
  26. </html>
  27. <script type="text/javascript">
  28. $(document).ready(function(){
  29. /* 定义所有class为copy标签,点击后可复制被点击对象的文本 */
  30. $(".copy").zclip({
  31. path: "ZeroClipboard.swf",
  32. copy: function(){
  33. return $(this).text();
  34. },
  35. beforeCopy:function(){/* 按住鼠标时的操作 */
  36. $(this).css("color","orange");
  37. },
  38. afterCopy:function(){/* 复制成功后的操作 */
  39. var $copysuc = $("<div class='copy-tips'><div class='copy-tips-wrap'>☺ 复制成功</div></div>");
  40. $("body").find(".copy-tips").remove().end().append($copysuc);
  41. $(".copy-tips").fadeOut(3000);
  42. }
  43. });
  44. /* 定义所有class为copy-input标签,点击后可复制class为input的文本 */
  45. $(".copy-input").zclip({
  46. path: "ZeroClipboard.swf",
  47. copy: function(){
  48. return $(this).parent().find(".input").val();
  49. },
  50. afterCopy:function(){/* 复制成功后的操作 */
  51. var $copysuc = $("<div class='copy-tips'><div class='copy-tips-wrap'>☺ 复制成功</div></div>");
  52. $("body").find(".copy-tips").remove().end().append($copysuc);
  53. $(".copy-tips").fadeOut(3000);
  54. }
  55. });
  56. });
  57. </script>
复制代码

demo下载 (温馨提示:下载代码的同学,浏览demo时记得使用服务器环境,不然看不到效果的~)

上面代码中结合jQuery的操作节点的功能,出色的发挥jquery.zclip.js的作用,如复制前后的操作,动态插入节点,也可见jquery.zclip.js的强大之处,使用起来是非常简单。需要深入了解更多jquery.zclip.js的功能请到http://www.steamdev.com/zclip/

从上面独立的js库ZeroClipboard.js和jquery.zclip.js 都是采用flash实现实现复制到剪贴板的功能,可以看出,使用ZeroClipboard.js带来功能相对比较少,不过它是独立的库,文件比较小,而使用jquery.zclip.js后的功能是比较丰富,不过对于不使用jQuery框架的站点来说,采用jquery.zclip.js是比较浪费宽带。使用哪种复制方式还是得看产品的具体定位情况~

 

//20170110补充clipboard.js实现复制到剪贴板

clipboard.js实现复制到剪贴板(含移动端ios复制)

 取代flash复制到剪切板,更好页面性能,不会造成卡顿想象,不止兼容PC端,还优雅的兼容移动端ios的safari浏览器,具体可以参考我做的项目https://wepayui.github.io/#/start/

官方文档及下载地址:https://clipboardjs.com/

如对本文有疑问,请提交到交流论坛,广大热心网友会为你解答!! 点击进入论坛

发表评论 (2314人查看0条评论)
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
昵称:
最新评论
------分隔线----------------------------

快速入口

· 365软件
· 杰创官网
· 建站工具
· 网站大全

其它栏目

· 建站教程
· 365学习

业务咨询

· 技术支持
· 服务时间:9:00-18:00
365建站网二维码

Powered by 365建站网 RSS地图 HTML地图

copyright © 2013-2024 版权所有 鄂ICP备17013400号