方法一:使用input
的 select()
方法
<!-- html -->
<div id="copy-target">
复制文本
</div>
<button onclick="copy('#copy-target')">复制</button>
<!-- js -->
<script>
function copy(target) {
// 获取目标复制内容
const txt = document.querySelector(target).innerText;
// 整一个input
var input = document.createElement("input");
// 赋值
input.setAttribute("value", txt);
// 添加节点
document.body.appendChild(input);
// 选取文本域中的内容
input.select();
// 复制
document.execCommand('Copy');
// 删除掉没用的节点
document.body.removeChild(input);
}
</script>
方法二:使用range
创建选中文本
function copy(target) {
// 创建range对象
var range = document.createRange();
// 传入需要选中的目标节点
range.selectNodeContents(document.querySelector