gpt4 book ai didi

JavaScript click() 方法仅在 Chrome 扩展程序中有效一次

转载 作者:数据小太阳 更新时间:2023-10-29 04:44:30 25 4
gpt4 key购买 nike

我正在尝试在 Chrome 扩展程序中下载多个文件。以下代码创建一个指向文件的虚拟链接,然后触发下载文件的 .click() 事件。问题是只有第一个 .click() 事件触发下载。随后的 .click() 事件将被忽略。

这里是 ma​​nifest.json:

{
"name": "Simple File Downloader",
"version": "0.1",
"permissions": ["contextMenus", "http://*/"],
"background": {
"persistent": false,
"scripts": ["sample.js"]
},
"content_security_policy": "script-src 'self'; object-src 'self'",
"manifest_version": 2
}

这里是 sample.js:

function onClickHandler(info, tab) {
var a = document.createElement('a');
a.href = 'http://or.cdn.sstatic.net/chat/so.mp3';
a.download = 'so.mp3';
document.body.appendChild(a);
a.click(); // this click triggers the download
// this timeout violates content security policy
// setTimeout(a, 300);
a.click(); // this click doesn't do anything
document.body.removeChild(a);

a = document.createElement('a');
a.href = 'http://or.cdn.sstatic.net/chat/so.mp3';
a.download = 'so.mp3';
document.body.appendChild(a);
a.click(); // this click doesn't do anything either
document.body.removeChild(a);
};

chrome.contextMenus.onClicked.addListener(onClickHandler);
chrome.runtime.onInstalled.addListener(function() {
chrome.contextMenus.create({"title": "Download File", "id":"download_file"});
});

我试过:

很惊讶为什么简单地保存多个文件如此困难。感谢任何帮助。

最佳答案

诀窍不是使用 element.click 方法,而是创建多个 MouseEvent。为此,您需要为每次需要点击创建一个 MouseEvent

function clicker(el, clickCount) {
var mousedownEvent;
while(clickCount--) {
mousedownEvent = document.createEvent("MouseEvent");
mousedownEvent.initMouseEvent("click", true, true, window, 0, null, null, null, null, false , false, false, false, 0, null);
el.dispatchEvent(mousedownEvent);
}
}

clicker(a, 3);
// your anchor 'a' gets clicked on 3 times.

虽然在 Chrome 中使用此方法时,您会收到浏览器的警告,询问 “此站点正在尝试下载多个文件。您要允许吗?[拒绝] [允许]” .所以,如果你在一个扩展的后台页面中这样做,后台页面会收到警告,用户看不到它,所以用户没有办法点击“允许”。

(严重/讨厌的)解决方法是创建一个“点击” anchor 的选项卡。像这样:

function _anchorDownloader(url, filename) {
var timeout = 500;
return 'javascript:\'<!doctype html><html>'+
'<head></head>' +
'<script>' +
'function initDownload() {'+
'var el = document.getElementById("anchor");'+
'el.click();' +
'setTimeout(function() { window.close(); }, ' + timeout + ');' +
'}'+
'</script>' +
'<body onload="initDownload()">' +
'<a id="anchor" href="' + url + '" download="'+ filename + '"></a>'+
'</body>' +
'</html>\'';
};

function downloadResource(info, tab) {
// ...
chrome.tabs.create( { 'url' : _anchorDownloader( url, filename ), 'active' : false } );
// ...
}

chrome.contextMenus.create({"title": "Save Image…", "contexts":["image"], "onclick": downloadResource });

为此,扩展必须在 ma​​nifest.json 中将 “tabs” 作为 permission。您可以调整超时以关闭选项卡,但是,如果您关闭它的速度太快,则不会发生下载。

关于JavaScript click() 方法仅在 Chrome 扩展程序中有效一次,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14033588/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com