gpt4 book ai didi

javascript - 使用 HTML5 下载不同位置的文件

转载 作者:行者123 更新时间:2023-11-28 03:56:51 27 4
gpt4 key购买 nike

我正在使用 HTML5 从下面的代码下载文件,您可以在 JSBIN HTML5 Download File DEMO 上看到这些代码的实际运行情况。并且它在我的浏览器默认下载文件夹中完美地文件和下载我的文件。

<!DOCTYPE html>
<html>
</head>
</head>
<body>
<table>
<tr><td>Text To Save:</td></tr>
<tr>
<td colspan="3">
<textarea id="inputTextToSave" style="width:512px;height:256px"></textarea>
</td>
</tr>
<tr>
<td>Filename To Save As:</td>
<td><input id="inputFileNameToSaveAs"></td>
<td><button onclick="saveTextAsFile()"> Save Text To File </button></td>
</tr>
<tr>
<td>Select A File To Load:</td>
<td><input type="file" id="fileToLoad"></td>
<td><button onclick="loadFileAsText()">Load Selected File</button><td>
</tr>
</table>
<script type='text/javascript'>
function saveTextAsFile()
{
var textToWrite = document.getElementById("inputTextToSave").value;
var textFileAsBlob = new Blob([textToWrite], {type:'text/plain'});
var fileNameToSaveAs = document.getElementById("inputFileNameToSaveAs").value;

var downloadLink = document.createElement("a");
downloadLink.download = fileNameToSaveAs;
downloadLink.innerHTML = "Download File";
if (window.webkitURL != null)
{
// Chrome allows the link to be clicked
// without actually adding it to the DOM.
downloadLink.href = window.webkitURL.createObjectURL(textFileAsBlob);
}
else
{
// Firefox requires the link to be added to the DOM
// before it can be clicked.
downloadLink.href = window.URL.createObjectURL(textFileAsBlob);
downloadLink.onclick = destroyClickedElement;
downloadLink.style.display = "none";
document.body.appendChild(downloadLink);
}
downloadLink.click();
}

function destroyClickedElement(event)
{
document.body.removeChild(event.target);
}

function loadFileAsText()
{
var fileToLoad = document.getElementById("fileToLoad").files[0];
var fileReader = new FileReader();
fileReader.onload = function(fileLoadedEvent)
{
var textFromFileLoaded = fileLoadedEvent.target.result;
document.getElementById("inputTextToSave").value = textFromFileLoaded;
};
fileReader.readAsText(fileToLoad, "UTF-8");
}
</script>
</body>
</html>

但我想在不同的位置下载它。就像我离线使用这段代码,并且在我的 index.html 文件中只有上面的代码。当我在浏览器中从 file:///C:/Users/Public/Desktop/ 运行此文件时,它会下载文件并将其保存在 file:///C:/用户/公共(public)/下载/。所以我想从调用它的地方下载这个文件。为此,我从以下代码中选择路径。它给我的路径为 /C:/Users/Public/Desktop/ 所以我想在这里保存文件。无论我的这个 index.html 文件在哪里,它都会下载该文件并将其保存在 index.html 文件中。这怎么可能?

var url = window.location.pathname;
var folderpath = url.substring(0,url.lastIndexOf('/')+1);
alert(folderpath);

最佳答案

这是不可能的,因为这会带来安全风险。人们为他们的文件夹结构使用相当真实的信息,访问文件夹名称本身会带来直接的风险。如此处所述:

Get browser download path with javascript

大多数操作系统倾向于默认下载位置,这是用户通过他们使用的浏览器决定的。不是网站。

在 Chrome 中,下载位置设置可以在 chrome://settings/downloads 找到

关于javascript - 使用 HTML5 下载不同位置的文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34870711/

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