js实现复制按钮

JavaScript014

js实现复制按钮,第1张

该方法允许运行命令来操纵可编辑内容区域

这里不得不说select()方法,这个方法是输入框独有的,即<input>和<textarea>,它可以选中输入框中的值,使输入框处于一个聚焦的状态。

步骤:

1、获取输入框

2、调用select()方法获取里面的值

3、使用浏览器提供的方法将其复制

input框实现

p标签实现

功能 :点击按钮,复制值。

实现方法 :通过原生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')

    }

点击复制地址栏里的地址?那么首先要知道当前地址:document.location.href。

然后点击复制,就是点击后获取值。

至于调用数据库:就是使用ajax,将点击获取到的值传进去发送到服务端即可。

服务端的事情,也就是获取发送来的值,根据只从那张数据表里面的什么字段中获取值,然后以json或者xml文档的形式发送回客户端

然后客户端就去处理获得的数据,并格式化显示再指定位置。