一键复制粘贴

一键复制粘贴功能需要用到一个轻量级的JS插件:clipboard.js。

官网地址:https://clipboardjs.com

下载到本地后,将其放入项目中,直接引用即可。具体实现代码如下:

<!DOCTYPE html>
<html>
      <head>
		<meta charset="UTF-8">
		<title>一键复制粘贴</title>
		<style>
		.transfer {
			width: 90%;
			margin: 20px auto;
			font-size: 18px;
		}
		.transfer button {
			margin-top: -5px;
			float: right;
			margin-left: 10px;
			background-color: rgb(3, 169, 244);
			width: 30%;
			height: 25px;
			font-size: 14px;
			color: white;
			border: 0;
		border-radius: 8%;
		}
		</style>
	</head>

	<body>
	<div class="transfer">
		支付宝:<span id="zfb_account">11111111111</span>
		<button onclick="copy1()" data-clipboard-action="copy" data-clipboard-target="#zfb_account" id="copy_zfb">一键复制</button>
	</div>
		<div class="transfer">
		微信:<span id="wx_account">2222222</span>
		<button onclick="copy2()" data-clipboard-action="copy" data-clipboard-target="#wx_account" id="copy_wx">一键复制</button>
		</div>
		<input type="text" />
	</body>

	<script type="text/javascript" src="../js/clipboard.min.js"></script>
	<script>
	function copy1() {
		var clipboard = new Clipboard('#copy_zfb');
		clipboard.on('success', function(e) {
		e.clearSelection(); //选中需要复制的内容
		alert("复制成功!");
		});
		clipboard.on('error', function(e) {
		alert("当前浏览器不支持此功能,请手动复制。")
		});
	}
		
	function copy2() {
		var clipboard = new Clipboard('#copy_wx');
		clipboard.on('success', function(e) {
		e.clearSelection(); //选中需要复制的内容
		alert("复制成功!");
		});
		clipboard.on('error', function(e) {
		alert("当前浏览器不支持此功能,请手动复制。")
		});
	}
	</script>

</html>

 

 

 


后续补充:

       在复制粘贴时,第二次点击就会弹出两次复制成功,第三次点击就会弹出三次,原因是每次点击后执行实例化一个clipboard对象,之前的clipboard对象并没有销毁,所以就会弹出多次。解决方法是:每次使用完成后销毁clipboard对象,这样既能解决现在的问题,也可以释放内存,优化代码。代码如下:无论复制成功或失败,都需要clipboard.destroy()。

function copy1() {

       var clipboard = new Clipboard('#copy_zfb');

       clipboard.on('success', function(e) {

           e.clearSelection(); //选中需要复制的内容

           alert("复制成功!");

          clipboard.destroy();

       });

       clipboard.on('error', function(e) {

           alert("当前浏览器不支持此功能,请手动复制。")

           clipboard.destroy();

       });

    }

 注意:如果你在项目中使用了其他的前端框架或者插件,有可能会与clipboard.js插件产生冲突。解决方法,可以使用<iframe/>标签,将此部分代码放在一个新的html文件中,然后在主文件中使用<iframe/>标签引入。


本人为JS实习生一枚,不断学习,不断进步,欢迎各位前辈批评指教。

### 回答1: AutoHotkey 是一款强大的自动化脚本编程语言和工具。使用 AutoHotkey,我们可以轻松地创建一键粘贴复制的功能。 首先,我们需要安装 AutoHotkey 软件,并创建一个新的脚本文件。在脚本文件中,我们可以使用一行简单的代码来实现一键粘贴复制的功能。 下面是一个示例代码: ^v:: Send, ^c Sleep 50 Send, {Ctrl down}v{Ctrl up} return 在这段代码中,^v 表示我们将使用 Ctrl+V 的组合键来触发这个功能。首先,我们使用 Send 指令将 Ctrl+C 发送到系统,将剪贴板中的内容复制到内存。然后,使用 Sleep 指令延迟 50 毫秒以确保复制操作已经完成。最后,使用 Send 指令模拟 Ctrl+V 操作,将复制的内容粘贴到当前的文本中。 保存脚本文件后,我们可以双击运行它,AutoHotkey 将在后台运行,并拦截我们在任何应用程序中按下 Ctrl+V 键的操作。当我们按下组合键时,复制的内容将自动粘贴到当前的光标位置上。 这就是如何使用 AutoHotkey 实现一键粘贴复制的功能。通过简单的几行代码,我们可以大大提高工作效率,减少重复劳动。 ### 回答2: AutoHotkey 是一款强大的自动化脚本语言,它可以用来自定义键盘快捷键,实现一键粘贴复制的功能。 首先,我们需要安装并运行 AutoHotkey 软件。接着,我们可以创建一个新的脚本文件,并在文件中编写代码来定义一键粘贴复制的功能。 下面是一个示例代码: ``` ; 设置快捷键 Ctrl+C 为复制 ^c:: Send, ^c return ; 设置快捷键 Ctrl+V 为粘贴 ^v:: Send, ^v return ``` 在上述代码中,"^c::" 表示设置快捷键为 Ctrl+C,"^v::" 则是设置快捷键为 Ctrl+V。"Send" 命令用来模拟键盘按键操作,"^c" 表示按下 Ctrl+C,"^v" 则表示按下 Ctrl+V。 保存脚本文件后,通过双击运行该文件,即可激活一键粘贴复制的功能。此时,按下 Ctrl+C 将会复制选定的文本,按下 Ctrl+V 则会粘贴复制的内容。 通过 AutoHotkey,我们可以根据自己的需要,自定义其他快捷键以实现更多的操作。例如,我们可以将一键粘贴复制绑定到其他按键组合上,以方便我们的使用。 总结来说,AutoHotkey 提供了一个简单且灵活的方式来实现一键粘贴复制的功能,帮助我们提高工作效率。 ### 回答3: AutoHotkey 是一款功能强大的自动化脚本语言和开源软件。它允许用户编写脚本来自动化各种任务。在使用 AutoHotkey 进行自动化时,我们可以使用一个简单的脚本来实现一键粘贴复制的功能。 首先,需要创建一个新的 AutoHotkey 脚本文件(以.ahk为后缀)。然后,在脚本文件中添加以下代码: ``` ^v:: Send, {Ctrl down}c{Ctrl up}{Ctrl down}v{Ctrl up} return ``` 这段代码的意思是,当我们按下Ctrl+V组合键时,脚本将模拟按下Ctrl+C(复制)和Ctrl+V(粘贴)的操作。 保存脚本后,双击运行脚本文件,它将在系统托盘中显示一个小图标,表示脚本正在运行。 现在,当我们需要进行一键粘贴复制时,只需按下Ctrl+V组合键即可。脚本将自动复制当前选定的文本,并将其粘贴到光标所在的位置。 除了Ctrl+V,我们还可以自定义其他快捷键来执行不同的操作。只需将"^v"改为所需的组合键即可。 总之,AutoHotkey 是一个非常有用的工具,可以轻松实现一键粘贴复制功能,提高工作效率。它还可以用来自动化各种其他任务,如模拟键盘、鼠标操作等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值