JS实现内容复制功能

JavaScript042

JS实现内容复制功能,第1张

复制是一个使用频率特别高的操作,在网页中,一般可以选中要复制的内容,使用快捷键 ctrl+c 将内容复制到剪贴板。除了使用系统提供的快捷方式复制网页内容,我们还可以用JS实现复制,这得益于document的 execCommand('copy') 命令。 实现整个复制功能,需要以下三个步骤: 大部分HTML元素都有innerText和innerHTML两个属性,innerText属性返回文本内容,innerHTML属性返回标签元素。我们可以创建一个函数,用于获取需要返回的内容: 上面的selectText函数接收一个DOM元素,返回DOM元素的innerText属性值。 我们可以通过表单元素的select()方法选中内容,表单元素因为textarea限制少于input,所以推荐使用textarea。我们可以动态创建一个textarea元素,将textarea的value属性值设置为上面的innerText属性值,再执行textarea的select方法选中。 上面实现了选中,下面就可以实现复制功能了。 最后一步就可以用execCommand('copy')实现复制了,它可以复制浏览器中选中的文本,比如说上面被textarea选中的文本,复制之后记得移除textarea。 第二步和第三步可以优化一下,创建一个copy函数,函数参数设置为第一步需要复制的文本,返回值为复制的结果。 完整JS示例如下: 可以将上面的完整JS示例写入一个JS文件,将JS文件引入HTML中,通过JS点击事件来执行复制函数。 效果图:

js实现点击后将文字或图片复制到剪贴板的方法,代码非常简洁实用,具体功能代码如下所示:

<table width="99%" border="0" cellpadding="0" cellspacing="0" class="firtable">

<tr>

<th width="100%" style="color: white"><s:text name="询单明细"></s:text></th>

</tr>

<tr>

<td align="center">

<textarea name="inquiryContact1" id="inquiryContact1" rows="15" cols="60" readonly="readonly"></textarea>

<div id="inquiryInfoDIV" style="display:none">

<s:property value="inquiryContact" escape="false"/>

</div>

<script>dojo.byId("inquiryContact1").innerText=dojo.byId("inquiryInfoDIV").innerText

</script>

</td></tr>

<tr>

<td align="center">

<input type="button" id="button" name="button" value="复制" onclick="copyContact()"/>

</td></tr></table>

<script type="text/javascript">

var i = 0

function copyContact(){

var contat = document.getElementById("inquiryContact1").value

window.clipboardData.setData('text', contat)

if(window.clipboardData.getData('text')==''){

if(i==1){

alert("复制失败,请手动Ctrl+C快捷键复制!")

}else{

alert("复制失败,请重新复制!")

i = 1

}

}else{

alert("内容已经复制到剪贴板!")

}

}

</script>

table表任意复制一行的关键是复制哪行,插入到什么位置,如何插入。第 一个问题复制哪行,通常是点击某一行以确定复制的当前行,核心代码如下:var e = window.eventif (e.target) targ = e.targetelse if (e.srcElement) targ = e.srcElementif (targ.nodeType == 3)targ = targ.parentNodeif(targ.tagName=="TD")第 二个问题插入位置,通常是点击行的下面pos = targ.parentNode.rowIndex+1也有可能在表头首行pos =0再就是表尾"beforeEnd"第三个问题如何插入,先复制当前行:var con = targ.parentNode.cloneNode(true)再进行插入,可以是insertRow,也可以是insertAdjacentElement:var x=document.getElementById('myTable').insertRow(pos);document.getElementById('myTable').insertAdjacentElement("beforeEnd",con)复制之后可对复制行里的内容进行修改调整:var y=x.insertCell(0).innerHTML=document.getElementById("cell1").value也可进行删除指定行:document.getElementById('myTable').removeChild(Obj.parentNode.rows[i])