clipboard.js 是一个不需要flash,将文本复制到剪贴板的插件。下面给大家介绍Vue中使用clipboard实现复制功能,具体内容如下所示:

首先现在Vue中引入clipboard

npm install clipboard --save

在需要使用的组件中import 引入clipboard

import Clipboard from 'clipboard';

clipboard的实际使用

不论是单按钮复制还是多按钮复制,一定要在页面加载DOM完成后先New出来具有复制功能的按钮,如果在函数内再New那么可能会出现点击复制按钮两次,才复制成功的现象,如下:

?

1

2

3

4

5

mounted() {

  var copybtn = document.getElementsByClassName('btn')

  this.clipboard = new Clipboard(copybtn);

  }

<!--并不一定非要在mounted中也可以在其他周期内,

    只要页面已经加载完DOM即可,如果是动态生成可以使用nextTick中New。-->

绑定复制内容的方式有以下几种:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

<!--第一种直接绑定在按钮上-->

 <button class="marleft10 btn" style="float: right;border: none;" :data-clipboard-text="2"

    @click="copy()">复制

    </button>

<!--第二种单个复制按钮动态获取需要复制的内容-->

<input type="text" v-model="copyContent" id="copy_text" style="opacity: 0">

<button ref="copy" data-clipboard-action="copy" data-clipboard-target="#copy_text" @click="copy">复制</button>

<!--第三种可以在New Clipboard时设定要复制的内容-->

new Clipboard('copyBtn',function(){

  return <!--要复制的内容-->

})

copy(){

  let _this = this

  <!--如果在内部new会出现点击两次在复制成功的现象所以还请各位多多注意-->

  clipboard.on('success', function () {

    Toast('复制成功')

    _this.destroy() <!--销毁缓存,然后在重新new这样不会出现点击复制上出现之前复制的内容的情况-->

    _this.clipboard = new Clipboard(copyBtn);

  })

  clipboard.on('error', function () {

    Toast('复制失败,请手动复制')

   })

  }

总结

以上所述是小编给大家介绍的Vue中使用clipboard实现复制功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对主机吧的支持!

Logo

前往低代码交流专区

更多推荐