实现方法 :通过原生js 的方法 document.execCommand('copy')
巨坑 :document.execCommand(‘copy’)不生效
原因 :
1.input框不能有disabled属性
2.根据第一条扩展,input的width || height 不能为0;
3.input框不能有hidden、display:none属性
解决方案 :在不改变原需求的情况下,新增一个input框,然后设置 opacity:0实现不可见, position:absolute脱离文档流解决占空间的问题
语法:
document.execCommand(aCommandName,aShowDefaultUI,aValueArgument),返回值Boolean 如果返回false 则表示还不能支持;
参数说明:
1.aCommandName
命令的名称:常用的为"copy","cut"等;
注:“copy” 拷贝当前选中内容到剪贴板
“cut” 剪贴当前选中的文字并复制到剪贴板
2.aShowDefaultUI
是否展示用户界面,一般为 false;
3.aValueArgument
默认为null,
示例
<!-- html -->
<!-- 点击复制输入框value值 -->
<input type="text" id="copyVal" value="被复制的内容" />
<!-- 点击复制div标签的innerHTML -->
<div id="copyInner">被复制的内容</div>
<button onclick="myCopy">点击复制</button>
// 方法一:点击按钮复制文本框内容
function myCopy(){
var copyVal = document.getElementById('copyVal')
copyVal.select()
document.execCommand('copy')
}
// 方法二:点击按钮复制div标签内容
function myCopy(){
const range = document.createRange()
range.selectNode(document.getElementById('copyInner'))
const selection = window.getSelection()
if(selection.rangeCount >0) selection.removeAllRanges()
selection.addRange(range)
document.execCommand('copy')
}
不能!
原因很简单:这涉及到个人隐私。
试想你在本地电脑或 a.com 复制或剪切了一些内容,然后浏览 b.com,如果 b.com 有能力获取用户复制或剪切的内容,这等于泄露了用户的个人隐私。
至于粘贴,你可以使用 Javascript 在文本框上监听键盘事件 (Ctrl + V / Shift + Ins) ,或者鼠标点击事件 (onmouseup),或者直接监听 onpaste。在这些事件被触发前,记录文本框内容,在事件被触发后,对比前后内容来获取被粘贴的数据。
获取被粘贴数据的代码较长,我写在空间了,如果有兴趣可以看一下。
hi.baidu.com/keneks/item/23f09b18d77075088ebde48b
1、最基本的复制Java代码
<script language="JavaScript">
function readTxt()
{
alert(window.clipboardData.getData("text"))
}
function setTxt()
{
var t=document.getElementById("txt")
t.select()
window.clipboardData.setData('text',t.createTextRange().text)
}
</script>
<input name="txt" value="测试">
<input type="button" value="复制" onclick="setTxt()">
<input type="button" value="读取" onclick="readTxt()">
2、扩展复制:复制表格
Java代码
<INPUT TYPE="button" value="选中测试表格" onclick="CopyTable()">
测试
<TABLE border="1" id="oTable">
<TR>
<TD>测试表格</TD>
<TD>测试表格</TD>
</TR>
<TR>
<TD>测试表格</TD>
<TD>测试表格</TD>
</TR>
</TABLE>文字
<SCRIPT LANGUAGE="JavaScript">
<!--
function CopyTable()
{
var txt = document.body.createTextRange()
txt.moveToElementText(document.getElementById('oTable'))
txt.select()
}
//-->
</SCRIPT>
、兼容IE,firefox等浏览器的复制
Java代码
<script>
function copyToClipboard(txt) {
if(window.clipboardData) {
window.clipboardData.clearData()
window.clipboardData.setData("Text", txt)
} else if(navigator.userAgent.indexOf("Opera") != -1) {
window.location = txt
} 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/clipboard1'].createInstance(Components.interfaces.nsIClipboard)
if (!clip)
return
var trans = Components.classes['@mozilla.org/widget/transferable1'].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-string1"].createInstance(Components.interfaces.nsISupportsString)
var copytext = txt
str.data = copytext
trans.setTransferData("text/unicode",str,copytext.length*2)
var clipid = Components.interfaces.nsIClipboard
if (!clip)
return false
clip.setData(trans,null,clipid.kGlobalClipboard)
}
}
</script>
<button onclick="copyToClipboard('你好!')">复制文本“你好!”</button>
<textarea id="test"></textarea>