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)
这有效但不是很好,因为它在视觉上有问题,缓慢且迂回。
该textarea元素应首先添加到实时 DOM 中,例如 todocument.body和 focus 因为execCommand在document.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 道具none或0像边框/填充/边距。
| 归档时间: |
|
| 查看次数: |
753 次 |
| 最近记录: |