码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 基于clipboard.js对复制组件的封装


    前言

    在日常开发中,有时可能想实现一键复制,我们可以选择手写复制方法,也可以选择引入 clipboard.js 库帮助快速实现功能

    本次封装组件使用  element-ui 的部分组件,有 icon 、message 等

    安装clipboard

    npm install clipboard --save

    子组件

    1. <template>
    2. <i :class="`${icon} icon-cursor`"
    3. title="点击复制"
    4. @click="handleCopy($event, text)" />
    5. template>
    6. <script>
    7. // 引入 clipboard.js
    8. import Clipboard from 'clipboard';
    9. export default {
    10. props: {
    11. // 接收复制的内容
    12. text: {
    13. type: [String, Number],
    14. default: null,
    15. },
    16. // 默认是复制 icon,可自定义 icon
    17. icon: {
    18. type: [String],
    19. default: 'el-icon-copy-document',
    20. },
    21. // 自定义成功提示
    22. message: {
    23. type: [String, Number],
    24. default: null,
    25. },
    26. },
    27. methods: {
    28. handleCopy (e, _text, message) {
    29. const clipboard = new Clipboard(e.target, { text: () => _text });
    30. // const messageText = message || `复制成功:${_text}`;
    31. const messageText = message || '复制成功';
    32. // 复制成功
    33. clipboard.on('success', () => {
    34. this.$message({
    35. type: 'success',
    36. message: messageText
    37. });
    38. clipboard.off('error');
    39. clipboard.off('success');
    40. clipboard.destroy();
    41. });
    42. // 复制失败
    43. clipboard.on('error', () => {
    44. this.$message({
    45. type: 'warning',
    46. message: '复制失败,请手动复制'
    47. });
    48. clipboard.off('error');
    49. clipboard.off('success');
    50. clipboard.destroy();
    51. });
    52. clipboard.onClick(e);
    53. },
    54. },
    55. };
    56. script>
    57. <style lang="scss" scoped>
    58. .icon-cursor {
    59. cursor: pointer;
    60. }
    61. style>

    父组件

    1. <script>
    2. import CopyIcon from '@/components/CopyIcon.vue'
    3. export default {
    4. components: {
    5. CopyIcon,
    6. },
    7. data () {
    8. return {
    9. value: '这里测试一下复制组件',
    10. };
    11. },
    12. };
    13. script>

    效果

    样式可以根据自己的需求修改,可以更换图标


    文章如有错误,恳请大家提出问题,本人不胜感激 。 不懂的地方可以评论,我都会 一 一回复

    文章对大家有帮助的话,希望大家能动手点赞鼓励,大家未来一起努力 长路漫漫,道阻且长

  • 相关阅读:
    审计专业毕业论文有什么好写一点的论文选题吗?
    熔断、限流、降级 —— SpringCloud Alibaba Sentinel
    2ED2410-EM:12v / 24v智能模拟高侧MOSFET栅极驱动器
    js基础笔记学习198-正则表达式简介1
    Selenium 4.11 正式发布--再也不用手动更新chrome driver 了
    【Java从入门到大牛】多线程
    发送邮件(三)
    【sw网络监控】通过snmp协议相关的snmp-exporter(收集交换机网络监控数据)+ promethus + grafana
    【【萌新的SOC学习之绪论】】
    2023年:我成了半个外包
  • 原文地址:https://blog.csdn.net/qq_52855464/article/details/126153751
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号