移动Web开发——复制操作

Posted baimeishaoxia

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了移动Web开发——复制操作相关的知识,希望对你有一定的参考价值。

上周接到一个需求——点击按钮,复制指定的文字到粘贴板。我也是第一次做这种功能,最后通过查资料实现了这个功能。

正文

其实这个功能实现起来也不难,主要用到了两个方法:execCommandselect

  • execCommand:可以让我们执行如复制、剪切、粘贴等命令,还可以改变字体颜色、大小等。更多具体的用法可以看这里,在这就不说了。

  • select:只有inputtextarea可以执行该方法;用于选取文本框中的内容。

有了这两个方法,前面的功能就有了大概的思路:首先动态创建input元素,然后动态制定input[value];执行select()进行选中,然后通过execCommand方法执行复制即可。
接下来就是代码实现了:

function copyContent(eleId){
    var temp = document.createElement("input")
    temp.setAttribute("value",document.getElementById(eleId).innerhtml)
    document.body.appendChild(temp)
    temp.select()
    document.execCommand("copy")
    document.body.removeChild(temp)
}

Demo地址

另一种方法

上面的方面虽然可以实现功能,但创建一个input元素然后再删掉感觉不太好,能不能直接copy指定DOM元素呢?其实是可以的,这里我们需要先介绍几个API:

  • document.createRange():返回一个Range对象,用来创建选中容器。

  • Range.selectNode(referenceNode):用来设定一个包含节点和节点内容的Range。

  • window.getSelection():返回一个 Selection 对象,表示用户选择的文本。

  • Selection.addRange(range):将一个区域(Range)对象加入选区。

  • Selection.removeRange(range)/removeAllRanges():从选区中移除一个区域/将所有的区域都从选区中移除。

要用到的API就上面这些,这里直接上Demo
下面是主要代码:

function copyToClipboard(eleId){
    var copyDOM = document.getElementById(eleId);
    var range = document.createRange();
    range.selectNode(copyDOM);
    window.getSelection().addRange(range);
    document.execCommand(‘copy‘);
    window.getSelection().removeAllRanges(); 
}


以上是关于移动Web开发——复制操作的主要内容,如果未能解决你的问题,请参考以下文章

Android课程---Android Studio使用小技巧:提取方法代码片段

用片段替换时操作栏向下移动

你可能不知道的JavaScript代码片段和技巧(下)

你可能不知道的JavaScript代码片段和技巧(上)

5、dom 结构操作怎样添加、移除、移动、复制、创建和查找节点

DOM操作 ——如何添加移除移动复制创建和查找节点等。