如何在Vue中使用clipboard.js复制服务端数据?

摘要:第一步 创建点击对象页面元素,并绑定业务数据。第二步 引入clipboard.js。第三步 创建ClipboardJS对象实例。第四步:替换clipboard对象实例的默认的onClick事件。

第一步 创建点击对象页面元素,并绑定业务数据。

<el-button type="text" size="mini" class="copy-button"

  :data-resource-type="scope.data.resource\_type"

  :data-resource-id="scope.data.resource\_id">

  复制链接

</el-button>

第二步 引入clipboard.js。

import ClipboardJS from 'clipboard';

第三步 创建ClipboardJS对象实例。



mounted() {

  this.clipboard = new ClipboardJS('.copy-button', {

    text: () => this.copyLink

  });

  

  ...

}

第四步:替换clipboard对象实例的默认的onClick事件。

mounted() {

  ...

  const that = this;

  const oldOnClick = this.clipboard.onClick;

  this.clipboard.onClick = function onClick(e) {

    const resource\_type = e.delegateTarget.getAttribute('data-resource-type');

    const resource\_id = e.delegateTarget.getAttribute('data-resource-id');

    console.log('resource\_type, resource\_id is', resource\_type, resource\_id)

    that.$axios

      .post(APIS.Link, {

        type: 'h5\_ugc\_detail',

        params: {ugc\_id: resource\_id, ugc\_type: resource\_type},

        \_csrf: that.$store.state.csrfToken

      })

      .then(res => {

        that.copyLink = res.data.data.link;

        oldOnClick.bind(that.clipboard)(e);

      })

      .catch(err => {

      });

  };

  ...

}

第五步:监听并处理操作成功与失败事件。

mounted() {

  ...

  this.clipboard.on('success', this.clipOptions.success);

  this.clipboard.on('error', this.clipOptions.error);

}

其中clipOptions类似如下:

computed: {

  clipOptions() {

    return {

      success: (e) => {

        this.$message.success('复制成功');

      },

      error: () => {

        this.$message.error('复制失败');

      }

    };

  },

  ...

}

第六步:vue生命周期结束时,销毁clipboard对象。

unmounted() {

  this.clipboard && this.clipboard.destroy();

}

本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!

链接: https://shenqiku.cn/article/FLY_6189