HTML中点击按钮复制span标签的内容js点击复制到剪切板板

JS实现各种复制到剪贴板 - 博客频道 - CSDN.NET
fanhu6816的博客
分类:javascripthtml5
一、实现点击按钮,复制文本框中的的内容
&script&type=&text/javascript&&
function copyUrl2()
var Url2=document.getElementById(&biao1&);
Url2.select(); // 选择对象
document.execCommand(&Copy&); // 执行浏览器复制命令
alert(&已复制好,可贴粘。&);
&textarea&cols=&20&&rows=&10&&id=&biao1&&用户定义的代码区域&/textarea&
&input&type=&button&&onClick=&copyUrl2()&&value=&点击复制代码&&/&
二、复制专题地址和 url 地址,传给 QQ/MSN 上的好友
&!DOCTYPE html PUBLIC &-//W3C//DTD XHTML 1.0 Transitional//EN& &&&
&html&xmlns=&&&
&meta&http-equiv=&Content-Type&&content=&text/ charset=gb2312&&/&
&title&Js复制代码&/title&
&input&type=&button&&name=&anniu1&&onClick='copyToClipBoard()'&value=&复制专题地址和url地址,传给QQ/MSN上的好友&&
&script&language=&javascript&&
function copyToClipBoard(){
var clipBoardContent=&&;
clipBoardContent+=document.
clipBoardContent+=&&;
clipBoardContent+=this.location.
window.clipboardData.setData(&Text&,clipBoardContent);
alert(&复制成功,请粘贴到你的QQ/MSN上推荐给你的好友&);
三、直接复制 url
&input&type=&button&&name=&anniu2&&onClick='copyUrl()'&value=&复制URL地址&&
&script&language=&javascript&&
function copyUrl()
var clipBoardContent=this.location.
window.clipboardData.setData(&Text&,clipBoardContent);
alert(&复制成功!&);
四、点击文本框时,复制文本框里面的内容
&input&onclick=&oCopy(this)&&value=&你好.要copy的内容!&&
&script&language=&javascript&&
function oCopy(obj){
obj.select();
js=obj.createTextRange();
js.execCommand(&Copy&)
alert(&复制成功!&);
五、复制文本框或者隐藏域中的内容
&script&language=&javascript&&
function CopyUrl(target){
target.value=myimg.
target.select();
js=myimg.createTextRange();
js.execCommand(&Copy&);
alert(&复制成功!&);
function AddImg(target){
target.value=&[IMG]&+myimg.value+&[/ img]&;
target.select();
js=target.createTextRange();
js.execCommand(&Copy&);
alert(&复制成功!&);
六、复制 span 标记中的内容
&script&type=&text/javascript&&
&script&type=&text/javascript&&function copyText(obj)
var rng = document.body.createTextRange();
rng.moveToElementText(obj);
rng.scrollIntoView();
rng.select();
rng.execCommand(&Copy&);
rng.collapse(false);
alert(&复制成功!&);
七、浏览器兼容& copyToClipboard(&拷贝内容&)
function&copyToClipboard(txt) {
&&&&&&if&(window.clipboardData) {
&&&&&&&&window.clipboardData.clearData();
&&&&&&&&clipboardData.setData(&Text&, txt);
&&&&&&&&alert(&复制成功!&);
&&&&&&}&else&if&(navigator.userAgent.indexOf(&Opera&) != -1) {
&&&&&&&&window.location =
&&&&&&}&else&if&(window.netscape) {
&&&&&&&&try&{
&&&&&&&&&&netscape.security.PrivilegeManager.enablePrivilege(&UniversalXPConnect&);
&&&&&&&&}&catch&(e) {
&&&&&&&&&&alert(&被浏览器拒绝!\n请在浏览器地址栏输入'about:config'并回车\n然后将 'signed.applets.codebase_principal_support'设置为'true'&);
&&&&&&&&var&clip = Components.classes['@mozilla.org/widget/1'].createInstance(Components.interfaces.nsIClipboard);
&&&&&&&&if&(!clip)
&&&&&&&&&&return;
&&&&&&&&var&trans = Components.classes['@mozilla.org/widget/1'].createInstance(Components.interfaces.nsITransferable);
&&&&&&&&if&(!trans)
&&&&&&&&&&return;
&&&&&&&&trans.addDataFlavor(&text/unicode&);
&&&&&&&&var&str =&new&Object();
&&&&&&&&var&len =&new&Object();
&&&&&&&&var&str = Components.classes[&@mozilla.org/supports-1&].createInstance(Components.interfaces.nsISupportsString);
&&&&&&&&var&copytext =
&&&&&&&&str.data =
&&&&&&&&trans.setTransferData(&text/unicode&, str, copytext.length * 2);
&&&&&&&&var&clipid = Components.interfaces.nsIC
&&&&&&&&if&(!clip)
&&&&&&&&&&return&false;
&&&&&&&&clip.setData(trans,&null, clipid.kGlobalClipboard);
&&&&&&&&alert(&复制成功!&);
八、兼容各大浏览器的复制代码(结合ZeroClipboard.js)
&title&Zero Clipboard Test&/title&
&script&type=&text/javascript&&src=&ZeroClipboard.js&&&/script&
&script&language=&JavaScript&&
&var clip =
&function $(id) { return document.getElementById(id); }
&function init() {
&&&&&clip = new ZeroClipboard.Client();
&&&&&clip.setHandCursor(true);&&&&
&&&&&clip.addEventListener('mouseOver', function (client) {
&&// update the text on mouse over
&&clip.setText( $('fe_text').value );
&&&&&clip.addEventListener('complete', function (client, text) {
&&//debugstr(&Copied text to clipboard: & + text );
&&alert(&该地址已经复制,你可以使用Ctrl+V 粘贴。&);
&&&&&clip.glue('clip_button', 'clip_container' );
&body&onLoad=&init()&&
&input&id=&fe_text&&cols=50&rows=5&value=复制内容文本1 &
&span&id=&clip_container&&&span&id=&clip_button&&&b&复制&/b&&/span&&/span&
排名:千里之外
(58)(29)(24)(20)(9)(1)(2)(5)(1)(1)(1)(1)(1)(1)(6)(6)(10)(1)(2)(1)(2)(2)(2)(6)(1)(1)(1)(1)(3)(2)(3)(1)(2)(1)(1)(6)(6)(1)(0)(4)(1)(1)(0)(1)(1)将内容复制到剪切板兼容主流浏览器的解决方案 - 简书
将内容复制到剪切板兼容主流浏览器的解决方案
如果仅仅使用javascript,是否能解决问题?
对于 Internet Explorer
function copyToClipBoard(copyText) {
if (window.clipboardData) { // ie
window.clipboardData.setData("Text", copyText);
对于其他浏览器,google了半天,发现不太好搞,比如对于firefox,要让网站的js有使用剪切板的权限是要用户授权的
看来就靠js是很难搞定了,还是得要靠外援flash呀。
兼容主流浏览器的最终解决方案
把一个不可见的 Adobe Flash movie元素放到一个DOM元素上。用户点击那DOM元素时,其实点击的是那不可见的Adobe Flash movie元素,Flash代码来做将内容复制到剪切板的操作。
注意:如果用js模拟一个在那flash上的点击事件,并不能进行复制内容到剪贴板。原因是浏览器和flash的安全限制。
&div class="demo-area"&
&label for="copy-input"&输入要复制到剪切板的文字:&/label&&br&
&textarea id="copy-input" cols="30" rows="10"&&/textarea&&br&
&button id="copy-button"&复制到剪贴板&/button&&br&
&script src="/jquery/1.9.0/jquery.js"&&/script&
&script src="path/to/ZeroClipboard.js"&&/script&
//配置ZeroClipboard.swf
ZeroClipboard.config({
swfPath: './vendor/ZeroClipboard.swf'
var client = new ZeroClipboard(document.getElementById("copy-button"));
client.on("ready", function(readyEvent) {
client.on("copy", function(event) {
var clipboard = event.clipboardD
var copyText = $('#copy-input').val();
clipboard.setData("text/plain", copyText); // 将内容添加到剪切板
完整的demo源码见我写的。
注意:由于要使用flash的缘故,一定要在服务器上运行这个demo。这里推荐个基于nodejs的静态服务器。
更多的关于ZeroClipboard的信息见它的
注:ZeroClipboard的2.0.2版本后不再支持IE8-。
前端攻城狮。爱编程,爱美食。问题对人有帮助,内容完整,我也想知道答案
问题没有实际价值,缺少关键内容,没有改进余地
我尝试过将文本prompt不行,里面没有内容,还尝试了点击弹出窗口,将文本放到textarea里面还是不行。
也试了 ZeroClipboard 这个jquery插件。但是使用的是flash。好像手机浏览器不支持。
答案对人有帮助,有参考价值
答案没帮助,是错误的答案,答非所问
这个方法 是绕了 一下,但是 iphone上就是不支持 flash 没有办法。。
答案对人有帮助,有参考价值
答案没帮助,是错误的答案,答非所问
黏贴复制,并不是html5的新技术,可以采用js来实现:
答案对人有帮助,有参考价值
答案没帮助,是错误的答案,答非所问
答案对人有帮助,有参考价值
答案没帮助,是错误的答案,答非所问
ZeroClipboard是基于flash的,手机上浏览器确实不能用,可以用这个clipboard.js,跨终端兼容:无需Flash无需依赖任何JS库实现文本复制与剪切:
答案对人有帮助,有参考价值
答案没帮助,是错误的答案,答非所问
哥们可以看看你的demo吗,我在做这个功能,遇到了问题
该答案已被忽略,原因:不符合答题规范:内容不是答案,可用评论、投票替代,无意义的内容:赞、顶、同问等毫无意义的内容
同步到新浪微博
分享到微博?
Hi,欢迎来到 SegmentFault 技术社区!⊙▽⊙ 在这里,你可以提出编程相关的疑惑,关注感兴趣的问题,对认可的回答投赞同票;大家会帮你解决编程的问题,和你探讨技术更新,为你的回答投上赞同票。
明天提醒我
关闭理由:
删除理由:
忽略理由:
推广(招聘、广告、SEO 等)方面的内容
与已有问题重复(请编辑该提问指向已有相同问题)
答非所问,不符合答题要求
宜作评论而非答案
带有人身攻击、辱骂、仇恨等违反条款的内容
无法获得确切结果的问题
非开发直接相关的问题
非技术提问的讨论型问题
其他原因(请补充说明)
我要该,理由是:
扫扫下载 App两天前听了一个H5的分享,会议上有一句话,非常有感触:不是你不能,而是你对自己的要求太低。很简单的一句话,相信很多事情不是大家做不到,真的是对自己的要求太低,如果对自己要求多一点,那么你取得的进步可能会更大。成长以来,很多朋友也听说到不少激励自己上进的话,但不是每个人都能一直坚持做下来,其实,这个跟自己的性格以及周围的环境都有很大关系,只能说多找方法、条件给自己鼓励,不断提高对自己的要求,才有机会获得多一点的成就。
目录(更新于,支持移动端ios复制)
今年下半年打算在组内建个叫『移动开发指南』的站点,在网站框架搭建过程,有一个功能需要实现复制文本到剪贴板,相信这个功能很常用,但是对于不常写JS代码的我来说是一个比较大的挑战,回想以前做过的一个站点,使用window.clipboardData实现复制到剪贴板功能,也仅仅支持IE和FF浏览器,当时在百度找个几个方案,看不下去就放弃了,后来在代码中做了判断,如果不支持该属性,就直接alert:此功能不支持该浏览器,请手工复制文本框中内容,现在想想真是偷懒啊,嘿嘿,有没有人中枪啊~
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的官方地址:,github地址:
使用它需要搭建服务器环境,可能有同学不太清楚,关于搭建服务器环境的,方法有很多,如xp或者win7系统自带的IIS,也可以使用、、等集成包,安装即可,搭建起来非常简单,这里不做介绍~
demo如下:
&!DOCTYPE html&
&title&Zero Clipboard Test&/title&
&meta charset="utf-8"&
1.data-clipboard-target 输入要复制的对象的ID
&button id="d_clip_button" class="my_clip_button" data-clipboard-target="fe_text"&&b&复制到剪贴板&/b&&/button&
&textarea id="fe_text" cols="50" rows="3"&输入需要复制的内容&/textarea&
&script type="text/javascript" src="ZeroClipboard.js"&&/script&
&script type="text/javascript"&
// 定义一个新的复制对象
var clip = new ZeroClipboard( document.getElementById("d_clip_button"), {
moviePath: "ZeroClipboard.swf"
// 复制内容到剪贴板成功后的操作
clip.on( 'complete', function(client, args) {
alert("复制成功,复制内容为:"+ args.text);
&(温馨提示:下载代码的同学,浏览demo时记得使用服务器环境,不然看不到效果的~)
上面代码注释中已经对Zero Clipboard的功能进行了介绍,需要了解更多的功能请到
&jQuery ZeroClipboard实现复制到剪贴板功能
jQuery ZeroClipboard是在ZeroClipboard的基础上进行的改良,简称zClip,作为jQuery的API,jQuery ZeroClipboard也表现的非常简易操作,官方地址:
使用前需引用2个js文件:和jquery.zclip.js
&script type="text/javascript" src="js/jquery.js"&&/script&
&script type="text/javascript" src="js/jquery.zclip.js"&&/script&
现在我们使用jquery.zclip.js简单实现复制到剪贴板功能demo如下:
&!DOCTYPE html&
&title&ZeroClipboard Test&/title&
&meta charset="utf-8"&
&style type="text/css"&
.line{margin-bottom:20px;}
/* 复制提示 */
.copy-tips{position:fixed;z-index:<span style="background-color: #f5f5f5; color: #;bottom:50%;left:50%;margin:<span style="background-color: #f5f5f5; color: # -20px -80px;background-color:rgba(0, 0, 0, 0.2);filter:progid:DXImageTransform.Microsoft.Gradient(startColorstr=#, endColorstr=#);padding:6px;}
.copy-tips-wrap{padding:10px 20px;text-align:center;border:1px solid #F4D9A6;background-color:#FFFDEE;font-size:14px;}
&script type="text/javascript" src="jquery.js"&&/script&
&script type="text/javascript" src="jquery.zclip.js"&&/script&
&div class="line"&
&h2&demo1 点击复制当前文本&/h2&
&a href="#none" class="copy"&点击复制我&/a&
&div class="line"&
&h2&demo2 点击复制表单中的文本&/h2&
&a href="#none" class="copy-input"&点击复制单中的文本&/a&
&input type="text" class="input" value="输入要复制的内容" /&
&script type="text/javascript"&
$(document).ready(function(){
/* 定义所有class为copy标签,点击后可复制被点击对象的文本 */
$(".copy").zclip({
path: "ZeroClipboard.swf",
copy: function(){
return $(this).text();
beforeCopy:function(){/* 按住鼠标时的操作 */
$(this).css("color","orange");
afterCopy:function(){/* 复制成功后的操作 */
var $copysuc = $("&div class='copy-tips'&&div class='copy-tips-wrap'&? 复制成功&/div&&/div&");
$("body").find(".copy-tips").remove().end().append($copysuc);
$(".copy-tips").fadeOut(3000);
/* 定义所有class为copy-input标签,点击后可复制class为input的文本 */
$(".copy-input").zclip({
path: "ZeroClipboard.swf",
copy: function(){
return $(this).parent().find(".input").val();
afterCopy:function(){/* 复制成功后的操作 */
var $copysuc = $("&div class='copy-tips'&&div class='copy-tips-wrap'&? 复制成功&/div&&/div&");
$("body").find(".copy-tips").remove().end().append($copysuc);
$(".copy-tips").fadeOut(3000);
&(温馨提示:下载代码的同学,浏览demo时记得使用服务器环境,不然看不到效果的~)
上面代码中结合jQuery的操作节点的功能,出色的发挥jquery.zclip.js的作用,如复制前后的操作,动态插入节点,也可见jquery.zclip.js的强大之处,使用起来是非常简单。需要深入了解更多jquery.zclip.js的功能请到
从上面独立的js库ZeroClipboard.js和jquery.zclip.js&都是采用flash实现实现复制到剪贴板的功能,可以看出,使用ZeroClipboard.js带来功能相对比较少,不过它是独立的库,文件比较小,而使用jquery.zclip.js后的功能是比较丰富,不过对于不使用jQuery框架的站点来说,采用jquery.zclip.js是比较浪费宽带。使用哪种复制方式还是得看产品的具体定位情况~
//补充clipboard.js实现复制到剪贴板
clipboard.js实现复制到剪贴板(含移动端ios复制)
&取代flash复制到剪切板,更好页面性能,不会造成卡顿想象,不止兼容PC端,还优雅的兼容移动端ios的safari浏览器,具体可以参考我做的项目
官方文档及下载地址:
最后,提前预祝大家中秋节快乐~
阅读(...) 评论()
朋友同事同行}

我要回帖

更多关于 span标签禁止点击 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信