将文件保存在用户HTML提到的文件夹中

时间:2017-02-13 14:58:54

标签: javascript html

我创建了一个代码,我希望在其中进行某些调整。 "将文本保存到文件"下载下载文件夹中的文本文件。我希望它能提示我走这条路。它应该问我在哪里保存文件,下载部分应该在后端发生,不应该是可见的。

以下是参考代码

<html>
<body>

<table>
    <tr><td>Text to Save:</td></tr>
    <tr>
        <td colspan="3">
            <textarea id="inputTextToSave" cols="80" rows="25"></textarea>
        </td>
    </tr>
    <tr>
        <td>Filename to Save As:</td>
        <td><input id="inputFileNameToSaveAs"></input></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 textToSave = document.getElementById("inputTextToSave").value;
    var textToSaveAsBlob = new Blob([textToSave], {type:"text/plain"});
    var textToSaveAsURL = window.URL.createObjectURL(textToSaveAsBlob);
    var fileNameToSaveAs = document.getElementById("inputFileNameToSaveAs").value;

    var downloadLink = document.createElement("a");
    downloadLink.download = fileNameToSaveAs;
    downloadLink.innerHTML = "Download File";
    downloadLink.href = textToSaveAsURL;
    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>

1 个答案:

答案 0 :(得分:0)

您无法使用JavaScript将文件下载到其他位置,因为这会给用户计算机带来安全风险。您唯一能做的就是将文本文件下载到用户下载文件夹中。但是,如果您确实需要将文件下载到其他目录,则可以使用浏览器扩展来执行此操作。也无法确保用户无法看到文件下载。如果您真的希望用户看不到文件下载,您可以通过下载使用驱动器,但这些错误通常会很快得到酒吧老板的修补。