当前位置: 首页 > article >正文

前端一键复制解决方案分享

需求背景

在这里插入图片描述

用户需要对流水号进行复制使用,前端的展示是通过样式控制,超出省略号表示,鼠标悬浮展示完整流水号。此处的鼠标悬浮展示采用的是:title='',这样就无法对文本进行选中。

下面是给出一键复制的不同的解决方案,希望对大家有所帮助。

  1. 使用UI框架中的Popover 弹出框
    如下图所示:

    在这里插入图片描述

    • 优点
      • 可以直接根据前端工程中使用到的UI库引入使用
    • 缺点
      • 需要用户手动选中文本进行复制,而且从项目全局考虑,为了样式的一致性可能会造成较大的改动
  2. ClipboardJS

    ClipboardJS 是一个轻量级的 JavaScript 库,主要用于实现剪贴板功能,让用户可以方便地复制文本。

    使用方法
    • npm 安装

      npm install clipboard --save
      
    • 引入
      import ClipboardJS from 'clipboard'
      
    • 样例
      <template>
      	<el-button type="primary" id="copy-button" @click="oneKeyCopy">一键复制</el-button>
      	<div class="container">
              <input v-model="logJson" />
          </div>
      </template>
      
      <script>
      import ClipboardJS from 'clipboard';
      export default {
          data() {
              return {
                  logJson: '哈哈哈',
      		}
      	},
          methods: {
              oneKeyCopy() {
                  let clipboard = new ClipboardJS('#copy-button', {
                      text: () => this.logJson,
                  });
                  clipboard.on('success', (e) => {
                      this.$message.success('复制成功!');
                      clipboard.destroy();
                  });
                  clipboard.on('error', () => {
                      this.$message.error('复制失败,请手动复制!');
                      clipboard.destroy();
                  });
                  clipboard.onClick(event => event.preventDefault()); // 阻止默认的点击事件
                  clipboard.click(); // 触发点击事件以执行复制操作
                  clipboard.destroy();
              },
      	}
      }
      </script>
      
  3. 原生JS
    基本用法
    // content:需要复制的内容
    const copyToClipboard = (content) => {
      const textarea = document.createElement("textarea")
      textarea.value = content
      document.body.appendChild(textarea)
      textarea.select()
      document.execCommand("Copy")
      textarea.remove()
    }
    
    兼容性

    不同的浏览器或版本对 execCommand 的支持程度不同

  4. navigator.clipboard.writeText

    navigator.clipboard.writeText 是一个现代浏览器提供的 API,用于将文本写入剪贴板。

    基本用法
    <!DOCTYPE html>
    <html lang="zh">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>复制文本示例</title>
    </head>
    <body>
        <textarea id="text-to-copy" rows="4" cols="50">这是需要复制的文本。</textarea><br>
        <button id="copy-button">复制文本</button>
    
        <script>
            document.getElementById('copy-button').addEventListener('click', function() {
                const text = document.getElementById('text-to-copy').value;
                
                navigator.clipboard.writeText(text)
                    .then(() => {
                        console.log('文本已复制:', text);
                        alert('文本已复制到剪贴板!');
                    })
                    .catch(err => {
                        console.error('复制失败:', err);
                    });
            });
        </script>
    </body>
    </html>
    
    代码解释
    • 通过 document.getElementById 获取文本域和按钮元素。
    • 为按钮添加点击事件监听器。
    • 在点击事件中,获取文本域中的值,并调用 navigator.clipboard.writeText(text)
    • 使用 .then() 方法处理成功情况,并在控制台输出信息或显示提示。
    • 使用 .catch() 方法处理错误情况。
    兼容性

    navigator.clipboard 是现代浏览器支持的特性(如 Chrome, Firefox, Edge 等),在某些旧版浏览器中可能不被支持。建议在使用前检查浏览器的兼容性。

    总结

    推荐方案2,方案1的使用需要考虑项目样式的一致性,可能会导致较多的内容改动;方案4和方案3均存在不兼容的情况。


http://www.kler.cn/a/354249.html

相关文章:

  • DataX与DataX-Web安装与使用
  • ubuntu22.04.5本地apt源部署
  • Pytorch | 利用PI-FGSM针对CIFAR10上的ResNet分类器进行对抗攻击
  • useContext Hook 的使用及规范
  • RHEL 7.5 源码安装 mysql-5.7.17 数据库
  • vue iframe进行父子页面通信并切换URL
  • Qt中的连接类型
  • 利用PHP爬虫API接口:高效获取数据的艺术
  • ICM20948 DMP代码详解(85)
  • hardhat部署智能合约
  • 面试感受(续)
  • 简单谈谈mysql中的日志 bin log
  • C语言数据结构—队列
  • Springboot中基于 IP 地址的请求速率限制拦截器
  • Java 创建图形用户界面(GUI)组件详解之JFrame、JTextField、JTextArea、JPasswordField、JScrollPane、JLabel
  • docker安装kafka并使用SASL 进行身份验证
  • 无人机组装、维护、飞行技术全能培训详解
  • WebGl 使用缓冲区对象绘制多个点
  • 建造者模式(C++)
  • MySQL日期类型选择建议
  • FPGA学习-将modelsim中的波形数据保存到TXT文件方便MATLAB画图分析
  • 023 elasticsearch查询数据 高亮 分页 中文分词器 field的数据类型
  • 【布隆过滤器】
  • 在生产制造领域,可视化大屏的作用可以说无可替代。
  • 用Java爬虫API,轻松获取taobao商品SKU信息
  • C++_Stack和Queue的使用及其模拟实现