我想知道如何禁用事件侦听器“复制”
我认为它是这样的:
.js 文件:
let btn = document.getElementById('btn');
document.body.addEventListener('click', function(e) {
if (e.target.id === 'btn') {
e.stopPropagation();
}
}, {
capture: false
});
提前致谢!
清单.json:
{
"name": "Test",
"version": "1.0",
"description": "Just testing!",
"manifest_version": 2,
"icons": {
"48": "images/icon_48.png",
"128": "images/icon_128.png"
},
"browser_action": {
"default_icon": "images/icon_16.png",
"default_popup": "popup.html"
}
}
要访问的网页,你需要一个内容脚本,因为在弹出的是一个有自己的DOM,一个单独的页面document
,window
,网址,应有尽有。
您还需要拦截copy
在 devtools 的事件侦听器面板中看到的事件:
manifest.json 应具有以下内容:
"content_scripts": [{
"matches": ["https://moller.jusbrasil.com.br/*"],
"js": ["content.js"],
"run_at": "document_start"
}]
内容.js:
window.addEventListener('copy', e => e.stopImmediatePropagation(), true);
让我们分解一下:
document_start
任何页面脚本之前运行true
意味着我们的监听器在事件调度过程的捕获阶段被调用——在任何其他标准冒泡阶段监听器之前window
是捕获阶段的第一个事件目标所以最终的结果是我们的监听器保证在页面监听器之前被调用。
PS 如您所见,此任务不需要 browser_action 弹出窗口。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句