vue 复制到粘贴板组件 vue-clipboard2

参考:

https://www.jb51.net/article/160136.htm

https://blog.csdn.net/JackieDYH/article/details/115551105

官网(推荐):

https://www.npmjs.com/package/vue-clipboard2

安装

npm install --save vue-clipboard2

引入

import Vue from 'vue'
import Clipboard from 'vue-clipboard2'
Vue.use(Clipboard)

vue文件中使用

<template>
    <div>
        <button type="dashed"
          v-clipboard:copy="code"
          v-clipboard:success="copyAddress"
          v-clipboard:error="copyAddressError"
        >复制内容</button>
    </div>
</template>
<script>
export default {
  name: "Home",
  data() {
    return {
      code : '20200829-20210324-20210329'
    };
  },
  methods:{
    // 复制
    copyAddress(e){
      console.log(e,"copyAddress");
    },
    copyAddressError(e){
      console.log(e,'copyAddressError');
    }
  }
};
</script>

vue文件方法中直接调用

<div id="app"></div>
  <template id="t">
    <div class="container">
    <input type="text" v-model="message">
    <button type="button" @click="doCopy">Copy!</button>
    </div>
  </template>
  <script>
  new Vue({
    el: '#app',
    template: '#t',
    data: function () {
      return {
        message: 'Copy These Text'
      }
    },
    methods: {
      doCopy: function () {
        this.$copyText(this.message).then(function (e) {
          alert('Copied')
          console.log(e)
        }, function (e) {
          alert('Can not copy')
          console.log(e)
        })
      }
    }
  })
</script>
vue-clipboard2是一个Vue.js插件,用于实现在Vue项目中复制文本内容或图片的功能。你可以通过安装和配置vue-clipboard2来使用它。 首先,你需要在你的项目中安装vue-clipboard2插件。可以使用npm或yarn命令来安装: ``` npm install vue-clipboard2 ``` 或 ``` yarn add vue-clipboard2 ``` 然后,在项目的main.js文件中引入vue-clipboard2插件,并配置autoSetContainer为true,以便自动设置复制容器: ``` import VueClipboard from 'vue-clipboard2' VueClipboard.config.autoSetContainer = true Vue.use(VueClipboard) ``` 接下来,你可以在你的Vue组件中使用v-clipboard指令来实现复制功能。例如,当点击一个div时复制相应的内容,可以按照以下方式编写代码: ```html <template> <div v-clipboard:copy="code" v-clipboard:success="onCopy" v-clipboard:error="onCopyError">点击复制</div> </template> ``` ```javascript data: function() { return { code: '我是复制的内容' } }, methods: { onCopy: function(e) { alert('复制内容 ' + e.text + '成功!'); }, onCopyError: function() { alert('您的手机系统不支持自动复制,请手动复制!'); } } ``` 这样,当点击该div时,相应的内容将被复制到剪贴板中,并触发相应的成功或失败回调函数。 如果你想复制图片,可以将img标签包装在一个div中,并在div上添加v-clipboard指令。例如: ```html <div v-clipboard:copy="code" v-clipboard:success="onCopy" v-clipboard:error="onCopyError"> <img src="xxxx" alt=" " /> </div> ``` 这样,当点击该div时,图片将被复制到剪贴板中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值