单击 Chrome 扩展程序的浏览器操作时将文本复制到剪贴板

twh*_*whb 2 javascript google-chrome-extension

我想点击我的 Chrome 扩展程序的浏览器操作按钮来复制一些文本,但网站上使用的方法不起作用。

(我意识到有一些类似的问题,但是他们回答在注入的脚本或浏览器操作弹出脚本中复制文本,而不是浏览器操作脚本。)

样板

清单.json:

{
    "name": "Example",
    "version": "0.0.0",
    "manifest_version": 2,
    "permissions": ["clipboardWrite"],
    "browser_action": {"default_title": "Copy some text"},
    "background": {
        "scripts": ["events.js"],
        "persistent": false
    }
}
Run Code Online (Sandbox Code Playgroud)

事件.js:

chrome.browserAction.onClicked.addListener(_ => {
    copy(new Date().toISOString().slice(0, 19))
})

// Define copy() here.
Run Code Online (Sandbox Code Playgroud)

方法一

不要定义copy并希望它像在控制台中那样全局定义。

不是。

方法二

function copy(text) {
    navigator.clipboard.writeText(text)
}
Run Code Online (Sandbox Code Playgroud)

失败并显示错误消息“DOMException: Document is not focus”。

方法三

function copy(text) {
    focus()
    navigator.clipboard.writeText(text)
}
Run Code Online (Sandbox Code Playgroud)

这与方法 2 的行为相同。

方法四

function copy(text) {
    const ta = document.createElement('textarea')
    ta.value = text
    ta.select()
    document.execCommand('copy')
    ta.remove()
}
Run Code Online (Sandbox Code Playgroud)

这将失败且没有错误消息。

方法五

将复制脚本注入活动选项卡。我没有编写这个代码,因为如果没有可访问的活动选项卡,选项卡与全局变量混淆,JS 在活动选项卡上暂停等,它会中断,并且还需要过多的权限。

方法六

function copy(text) {
    open('copy.html?' + encodeURIComponent(text), '', 'width=1,height=1')
}
Run Code Online (Sandbox Code Playgroud)

(设置宽度和高度会强制打开窗口,而不是选项卡,以保留用户的选项卡选择并减少视觉冲击。)

复制.html:

{
    "name": "Example",
    "version": "0.0.0",
    "manifest_version": 2,
    "permissions": ["clipboardWrite"],
    "browser_action": {"default_title": "Copy some text"},
    "background": {
        "scripts": ["events.js"],
        "persistent": false
    }
}
Run Code Online (Sandbox Code Playgroud)

复制.js:

(async _ => {
    await navigator.clipboard.writeText(decodeURIComponent(location.search.slice(1)))
    close()
})()
Run Code Online (Sandbox Code Playgroud)

这有效但不是很好,因为它在视觉上有问题,缓慢且迂回。

wOx*_*xOm 5

textarea元素应首先添加到实时 DOM 中,例如 todocument.body和 focus 因为execCommanddocument.activeElement. 您可以隐藏 textarea 使其不闪烁。

function copy(text) {
  const ta = document.createElement('textarea');
  ta.style.cssText = 'opacity:0; position:fixed; width:1px; height:1px; top:0; left:0;';
  ta.value = text;
  document.body.appendChild(ta);
  ta.focus();
  ta.select();
  document.execCommand('copy');
  ta.remove();
}
Run Code Online (Sandbox Code Playgroud)

为了以防万一,可能想设置更多的 CSS 道具none0像边框/填充/边距。