JS复制对应id的内容到粘贴板(Ctrl+C效果)


Posted in Javascript onJanuary 23, 2017

前言

最近在做一个按钮,实现的效果是当点击后复制url到黏贴板,但不是当前页面url,而是对应一个元素的url,且一个页面会有多个url。一开始找到一个方法,但是竟然只兼容IE浏览器,神奇了,竟然有只兼容IE的东西。后来发现一个zeroclipboard.js这个插件,但是怎么也搞不出那个效果,有点麻烦。

最后翻到了一个js封装好的方法,有效!

想要实现的一个效果是,下面html代码:

<tr>
 <td>
 <a id="copy_{$key}" onclick="getUrl('{$key}')">复制文件链接</a>
 <input id="file_{$key}" value="{$file.file_url}" style="margin-left: -9999px"/>
 </td>
</tr>

点击复制文件链接这个按钮,复制input框里的value值,是传进去的一个url;首先点击a标签会触发getUrl这个函数;传进去id用于找到对应的input然后取值(因为遍历了多个td,有许多个input框一一对应去取)。

下面js代码:

<pre><script type="application/javascript">
 
 function getUrl(id) {
  if (copyToClipboard(document.getElementById("file_"+id))){
   alert("成功复制到黏贴板!");
  }else{
   alert("复制到黏贴板失败!");
  }
 }
 
 function copyToClipboard(elem) {
  // create hidden text element, if it doesn't already exist
  var targetId = "_hiddenCopyText_";
  var isInput = elem.tagName === "INPUT" || elem.tagName === "TEXTAREA";
  var origSelectionStart, origSelectionEnd;
  if (isInput) {
   // can just use the original source element for the selection and copy
   target = elem;
   origSelectionStart = elem.selectionStart;
   origSelectionEnd = elem.selectionEnd;
  } else {
   // must use a temporary form element for the selection and copy
   target = document.getElementById(targetId);
   if (!target) {
    var target = document.createElement("textarea");
    target.style.position = "absolute";
    target.style.left = "-9999px";
    target.style.top = "0";
    target.id = targetId;
    document.body.appendChild(target);
   }
   target.textContent = elem.textContent;
  }
  // select the content
  var currentFocus = document.activeElement;
  target.focus();
  target.setSelectionRange(0, target.value.length);
 
  // copy the selection
  var succeed;
  try {
   succeed = document.execCommand("copy");
  } catch(e) {
   succeed = false;
  }
  // restore original focus
  if (currentFocus && typeof currentFocus.focus === "function") {
   currentFocus.focus();
  }
 
  if (isInput) {
   // restore prior selection
   elem.setSelectionRange(origSelectionStart, origSelectionEnd);
  } else {
   // clear temporary content
   target.textContent = "";
  }
  return succeed;
 }
</script></pre>

getUrl中调用了封装好的copyToClipboard方法实现了功能。有一点的是html中input的样式用style="margin-left: -9999px"进行隐藏,因为不知道为什么用type="hiden"或者display="none"去隐藏都只会获取源代码而不是动态的url遍历出来的值。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

Javascript 相关文章推荐
JS event使用方法详解
Apr 28 Javascript
动态载入/删除/更新外部 JavaScript/Css 文件的代码
Jul 03 Javascript
js获取图片大小的函数代码
Sep 20 Javascript
js控制的遮罩层实例介绍
May 29 Javascript
选择复选框按钮置灰否则按钮可用
May 22 Javascript
JQuery中serialize()、serializeArray()和param()方法示例介绍
Jul 31 Javascript
JavaScript中操作Mysql数据库实例
Apr 02 Javascript
Angular中响应式表单的三种更新值方法详析
Aug 22 Javascript
详解使用webpack打包编写一个vue-toast插件
Nov 08 Javascript
基于vue实现一个禅道主页拖拽效果
May 27 Javascript
layui的表单验证支持ajax判断用户名是否重复的实例
Sep 06 Javascript
解决vue+ element ui 表单验证有值但验证失败问题
Jan 16 Javascript
JavaScript常用正则验证函数实例小结【年龄,数字,Email,手机,URL,日期等】
Jan 23 #Javascript
Node.js Express 框架 POST方法详解
Jan 23 #Javascript
js 颜色选择插件
Jan 23 #Javascript
JavaScript常用正则函数用法示例
Jan 23 #Javascript
详解微信小程序 wx.uploadFile 的编码坑
Jan 23 #Javascript
微信小程序侧边栏滑动特效(左右滑动)
Jan 23 #Javascript
微信小程序技巧之show内容展示,上传文件编码问题
Jan 23 #Javascript
You might like
php urlencode()与urldecode()函数字符编码原理详解
2011/12/06 PHP
PHP图片处理类 phpThumb参数用法介绍
2012/03/11 PHP
基于php验证码函数的使用示例
2013/05/03 PHP
PHP的cURL库简介及使用示例
2015/02/06 PHP
PHP实现即时输出、实时输出内容方法
2015/05/27 PHP
php结合正则获取字符串中数字
2015/06/19 PHP
thinkPHP数据库增删改查操作方法实例详解
2016/12/06 PHP
Yaf框架封装的MySQL数据库操作示例
2019/03/06 PHP
PHP中有关长整数的一些操作教程
2019/09/11 PHP
jquery Firefox3.5中操作select的问题
2009/07/10 Javascript
在IE和VB中支持png图片透明效果的实现方法(vb源码打包)
2011/04/01 Javascript
javascript中的delete使用详解
2013/04/11 Javascript
兼容主流浏览器的iframe自适应高度js脚本
2014/01/10 Javascript
javascript中caller和callee详解
2015/08/10 Javascript
Highcharts学习之坐标轴
2016/08/02 Javascript
AngularGauge 属性解析详解
2016/09/06 Javascript
jQuery实现用户输入自动完成功能
2017/02/13 Javascript
AngularJS实现controller控制器间共享数据的方法示例
2017/10/30 Javascript
探索Vue高阶组件的使用
2018/01/08 Javascript
详解webpack-dev-server的简单使用
2018/04/02 Javascript
Nodejs 发布自己的npm包并制作成命令行工具的实例讲解
2018/05/15 NodeJs
基于 jQuery 实现键盘事件监听控件
2019/04/04 jQuery
使用JavaScript获取扫码枪扫描得到的条形码的思路代码详解
2020/06/10 Javascript
vue数据更新UI不刷新显示的解决办法
2020/08/06 Javascript
python获取豆瓣电影简介代码分享
2014/01/16 Python
python 字典中文key处理,读取,比较方法
2018/07/06 Python
pygame游戏之旅 创建游戏窗口界面
2018/11/20 Python
Python常见读写文件操作实例总结【文本、json、csv、pdf等】
2019/04/15 Python
解决TensorFlow训练内存不断增长,进程被杀死问题
2020/02/05 Python
Python迭代器协议及for循环工作机制详解
2020/07/14 Python
CSS3制作Dropdown下拉菜单的方法
2015/07/18 HTML / CSS
比利时家具购买网站:Home24
2019/01/03 全球购物
私人会所最新创业计划书范文
2014/03/24 职场文书
学习保证书怎么写
2015/02/26 职场文书
病房管理制度范本
2015/08/06 职场文书
高一军训口号
2015/12/25 职场文书