实现方法 :通过原生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')
}
1、首先建立一个父级页面parent.html,代码如图,一个pop函数方法,一个链接到child.html的iframe标签。
2、再新建一个child.html页面,如图,展示一个id=link的div标签,和link的点击事件,因为是调用父级方法,所以需要用到window.parent.pop()方法。
3、预览页面,可明显看到parent.html里面的iframe框架,指向的就是child子页面。
4、点击页面中“调用父级pop方法”的文字链,会提示错误,这是因为没配置好域名等相关设置。
5、打开iis,右键iframe文件夹——“管理文件夹”——“浏览”;即可打开本地测试地址;(如小伙伴没配置iis,需要先配置iis建立站点)。
6、再次点击“调用父级pop方法”的文字链,即可成功弹出提示。
clipboard.js 是一个不需要flash,将文本复制到剪贴板的插件。简单介绍下基本运用。
<pre>
<script src="js/clipboard.min.js"></script>
</pre>
首先需要您需要通过传递DOM选择器,HTML元素或HTML元素列表来实例化它。
<pre>
new Clipboard('.btn')
</pre>
1用一个元素当触发器来复制另一个元素的文本,data-clipboard-target属性后需要跟属性选择器
<pre>
<input id="foo" value="https://github.com/zenorocha/clipboard.js.git">
<button class="btn" data-clipboard-target="#foo">
</button>
</pre>
另外还有另外一个属性data-clipboard-action属性,以指定是要要么copy还是要cut操作。默认情况下是copy。cut操作只适用于<input>或<textarea>元素。
<pre>
<textarea id="bar">Mussum ipsum cacilds...</textarea>
<button class="btn" data-clipboard-action="cut" data-clipboard-target="#bar">
Cut to clipboard
</button>
</pre>
2从属性中复制文本,不需要另一个元素当触发器,可以使用data-clipboard-text属性,在后面放上需要复制的文本.
<pre>
<button class="btn" data-clipboard-text="Just because you can doesn't mean you should — clipboard.js">
Copy to clipboard
</button>
</pre>
1通过运行检查clipboard.js是否支持Clipboard.isSupported(),返回true则可以使用。
2显示一些用户反馈或捕获在复制/剪切操作后选择的内容。操作,文本,触发元素
<pre>
var clipboard = new Clipboard('.btn')
</pre>
3该插件使用的是事件委托的方式来触发,所以大大减少了对dom的操作。
如果你不想修改你的HTML,那么你可以使用一个非常方便的命令API。所有你需要做的是声明一个函数,写下你想要的操作,并返回一个值。下面是一个对不同id的触发器返回不同的值的例子。具体的使用方法请看 https://clipboardjs.com
<pre>
<body>
<input id="foo" value="https://github.com/zenorocha/clipboard.js.git">
<button id='foo_1' class="btn" data-clipboard-target="#foo">
</button>
</body>
<script>
new Clipboard('.btn', {
text: function(trigger) {
if(trigger.getAttribute('id')=='foo_1'){
return 1
}else{
return 2
}
}
})
</script>
</pre>
谷歌42+,火狐41+,其他自己查看 https://clipboardjs.com