首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在clipboardData上使用removeEventListener?

如何在clipboardData上使用removeEventListener?
EN

Stack Overflow用户
提问于 2018-08-14 22:20:42
回答 1查看 801关注 0票数 1

页面上有一个按钮,可以将文本复制到剪贴板,代码如下:

代码语言:javascript
复制
export class ClipboardService {
    static copyToClipboard(toCopy: string) : void {
        document.addEventListener('copy', (e : ClipboardEvent) => {
            e.clipboardData.setData('text/plain', toCopy);
            e.preventDefault();
        });
        document.execCommand('copy');
    }
} 

但是在使用之后,这个代码Ctrl+C不起作用。我需要像这样的removeEventListener

代码语言:javascript
复制
export class ClipboardService {
    static copyToClipboard(toCopy: string) : void {
        document.addEventListener('copy', (e : ClipboardEvent) => {
            e.clipboardData.setData('text/plain', toCopy);
            e.preventDefault();
        });
        document.execCommand('copy');

        document.removeEventListener('copy', (e : ClipboardEvent) => {
            e.clipboardData.??? // I stuck in this place.
        });
    }
}

如何在复制来自特定字段的文本时返回到剪贴板的标准行为?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-08-14 22:37:36

问题是您试图通过重新编写函数来删除该函数。在JS中,即使代码完全相同,两个函数仍然是不同的函数。

因此,您需要有一个对函数的引用,以便能够在两个调用中使用它:

代码语言:javascript
复制
export class ClipboardService {
static copyToClipboard(toCopy: string) : void {
    const create_copy = (e : ClipboardEvent) => {
        e.clipboardData.setData('text/plain', toCopy);
        e.preventDefault();
    };
    document.addEventListener('copy', create_copy );
    document.execCommand('copy');
    document.removeEventListener('copy', create_copy );
}

}

票数 11
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51843684

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档