前端实用技能(一键复制代码)

最近在写文章的时候发现,现在各大平台都有复制代码的功能,于是勇宝就产生了好奇具体怎么实现的,今天带着大家一起来写一写。

具体的效果就是点击复制代码,然后右上角弹出提示框,过一两秒自己就消失了。

一、核心原理

复制代码的方式有很多,这里我只讨论最常用的一种,这个APIBOM的一个方法navigator.clipboard

值得一提的是clipboard是异步的,可以返回一个Promise,相信小伙伴们对Promise不是很陌生了吧,买个坑,以后来填。

本次案例我们只用到了writeText

  • writeText:用来把我们要复制的内容写入到我们的剪切板
  • readText:用来获取我们剪切板中的内容

二、案例展示

这里主要是带着大家一起来实现这个简单又有趣的小案例,主要是带领大家熟悉和认识BOM的一些API

1. html模版

  1. 这里我就写一个textarea框来模拟展示我们的输入内容。

    html 复制代码
    <body>
        <div class="block">
            <textarea id="text" cols="30" rows="10"></textarea>
        </div>
        <button>一键复制</button>
    </body>
  2. 编写弹出框用来提示复制成功,默认不显示display:none;

    html 复制代码
    <body>
        <div class="alert">复制成功</div>
        <div class="block">
            <textarea id="text" cols="30" rows="10"></textarea>
        </div>
    </body>

    顺便我们在编写一下弹出框的样式,让它看起来更像。

    css 复制代码
    .alert {
        display: none;
        position: fixed;
        right: 10px;
        padding: 1rem 2rem;
        max-width: 15rem;
        font-size: 1.167rem;
        color: #007bff;
        background-color: #e6f3ff;
        box-shadow: 0 1px 1px 0 hsl(0deg 0% 80% / 50%);
        border: 1px solid #b3d0ef;
        border-radius: 2px;
        cursor: default;
    }

2. JS逻辑

有两个功能是要我们在这一部分中实现的,一个是点击一键复制按钮,弹出提示框,过两秒后移除,另一个是当我们点击一键复制后通过ctrl+V能够粘贴我们文本框中输入的内容

  1. 先来获取我们需要的DOM元素

    js 复制代码
    const btn = document.getElementById('btn'), // 一键复制的按钮
          text = document.getElementById('text'), // 文本框
          alert = document.getElementById('msg'); // 弹框
  2. 这里我们定义一个定时器,顺便来定义一下剪切板

    js 复制代码
    let timer = null
    let clipboard = navigator.clipboard
  3. 给我们的按钮添加监听事件

    js 复制代码
    btn.addEventListener('click', async () => {
        // 因为返回的是Promise,所以可以使用async和await
        await clipboard.writeText(text.value)
        alert.style.display = 'inline-block'
        // 这里简单写一下就是为了不重复生成定时器
        if (!timer) {
            timer = setTimeout(() => {
                alert.style.display = 'none'
                timer = null
            }, 2000)
        }
    })
  4. 然后我们就可以在其他地方使用ctrl+V进行粘贴啦!!!

三、案例完整代码

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        .alert {
            display: none;
            position: fixed;
            right: 10px;
            padding: 1rem 2rem;
            max-width: 15rem;
            font-size: 1.167rem;
            color: #007bff;
            background-color: #e6f3ff;
            box-shadow: 0 1px 1px 0 hsl(0deg 0% 80% / 50%);
            border: 1px solid #b3d0ef;
            border-radius: 2px;
            cursor: default;
        }
    </style>
</head>

<body>
    <div class="alert" id="msg">复制成功</div>
    <div class="block">
        <textarea id="text" cols="30" rows="10"></textarea>
    </div>
    <button id="btn">一键复制</button>
    <script>
        const btn = document.getElementById('btn'),
            text = document.getElementById('text'),
            alert = document.getElementById('msg');

        let timer = null
        let clipboard = navigator.clipboard  

        btn.addEventListener('click', async () => {
            await clipboard.writeText(text.value)
            alert.style.display = 'inline-block'
            if (!timer) {
                timer = setTimeout(() => {
                    alert.style.display = 'none'
                    timer = null
                }, 2000)
            }
        })
    </script>
</body>

</html>

四、总结

前端开发中BOMDOM一样重要,学好了对我们自身的技能都是有很大的提升,今天就不总结那么多了,总之就是今天又学会了一个知识点,我开心(^▽^)

相关推荐
清汤饺子1 天前
OpenClaw 本地部署教程 - 从 0 到 1 跑通你的第一只龙虾
前端·javascript·vibecoding
颜酱1 天前
图的数据结构:从「多叉树」到存储与遍历
javascript·后端·算法
爱吃的小肥羊1 天前
比 Claude Code 便宜一半!Codex 国内部署使用教程,三种方法任选一!
前端
IT_陈寒1 天前
SpringBoot项目启动慢?5个技巧让你的应用秒级响应!
前端·人工智能·后端
树上有只程序猿1 天前
2026低代码选型指南,主流低代码开发平台排名出炉
前端·后端
橙某人1 天前
LogicFlow 小地图性能优化:从「实时克隆」到「占位缩略块」!🚀
前端·javascript·vue.js
高端章鱼哥1 天前
为什么说用OpenClaw对打工人来说“不划算”
前端·后端
大脸怪1 天前
告别 F12!前端开发者必备:一键管理 localStorage / Cookie / SessionStorage 神器
前端·后端·浏览器
Mr_Mao1 天前
我受够了混乱的 API 代码,所以我写了个框架
前端·api
小徐_23331 天前
向日葵 x AI:把远程控制封装成 MCP,让 AI 替我远程控制设备
前端·人工智能