2

我只是在尝试使用java脚本的文件操作系统。正如我从 W3C 文件 API ( https://www.w3.org/TR/FileAPI/ ) 中提到的,我们只能读取本地文件,例如

var file = "test.txt";
function readTextFile(file) {
   var readFile;    
   if(window.XMLHttpRequest){
      // for new browsers
      readFile = new XMLHttpRequest();
   }else{
      //for old browsers like IE5 or IE6
      readFile = new ActiveXObject("Microsoft.XMLHTTP");
   }    
   readFile.open("GET", file, true);
   readFile.onreadystatechange = function() {
      if(readFile.readyState === 4) {
         if(readFile.status === 200 || readFile.status == 0) {
            //text will be displayed that read from the file
            console.log(readFile.responseText);
         }
      }
   }
   readFile.send(null);
}

但它看起来没有选项可以在没有服务器的情况下写入文件。我试图从http://www.stackoverflow.com/等网站获取解决方案,研究表明几乎没有任何可能性。

例如,我得到的是

来自https://gist.github.com/Arahnoid/9925725

它显示错误“TypeError:file.open 不是函数。”

所以我的问题是,是否有可能在不使用服务器端脚本的情况下对本地文件进行文件操作(仅询问写入文件),或者是否有任何可用的扩展?

我们可以使用 PHP、Node.js 等服务器脚本语言进行文件操作。

提前致谢。

4

1 回答 1

3

在您的代码中,它不是从本地文件 ( test.txt) 中读取,而是向服务器发送 AjaxGET请求并在服务器端读取文件。

要读取本地文件(存储在安装浏览器的机器中的文件),您需要使用 FileAPI,当前代码中未使用该文件。

要将文件写入本地,不可能直接使用 JavaScript 编写。否则,这将是一个巨大的安全漏洞。但是,您可以从 File 对象生成一个 URL,并将该 URL 用作标签的href属性<a>,以便用户可以手动下载和“写入本地”。

这是读取和“写入”本地文件的代码片段:

var inputElement = document.getElementById("input");
var reader = new FileReader();
var downloadLink = document.getElementById('downloadLink');

reader.onloadend = function(){
  console.log(reader.result);
}
inputElement.addEventListener("change", handleFiles, false);
function handleFiles() {
  var fileSelected = this.files[0]; /* now you can work with the file list */
  reader.readAsBinaryString(fileSelected);
  downloadLink.href = window.URL.createObjectURL(fileSelected);
}
<input type="file" id="input">
<a id="downloadLink" download>Download</a>

于 2017-05-12T10:02:36.313 回答