我找遍了所有的地方,但是我找不到一个能在Chrome上重复读取本地文本文件(和我的js和html文件在同一个文件夹中)的解决方案。
我需要不断地读取文件的更新,另一个程序会自动更新,我不知道怎么做。这只是一个常规的text.txt文件。
我已经在这里读到了很多关于它的问题/答案,但到目前为止我什么也没找到。有人能帮上忙吗?
编辑:我的意思是没有节点,只有普通的JS。
发布于 2018-12-14 05:46:34
您可以通过starting Chrome with it's security features disabled为本地文件启用XmlHttpRequest。这不是一个理想的解决方案,但它是自动执行所需操作的唯一方法,而无需运行某种类型的服务器。使用Node监视文件的更改并通过WebSocket将数据推送到浏览器将是处理此问题的正确方法。
或者,您也可以使用FileReader API打开这个本地文件,但是需要首先通过<input type="file">
元素手动选择它。
function readInputFile(event) {
let file = event.target.files[0];
if (!file) {
return;
}
let reader = new FileReader();
reader.addEventListener('load', event => {
let content = event.target.result;
alert(content);
});
reader.readAsText(file);
}
document.getElementById('datafile').addEventListener('change', readInputFile, false);
<input type="file" id="datafile">
发布于 2018-12-14 04:20:22
我想你可能会对“本地”文件在这种情况下是什么感到困惑。
本地文件将使用诸如file://
之类的url加载,或者从表单中输入的文件中选择。
您的.html和.css旁边的文件不是本地文件,而是您用来托管.html的web服务器上的托管文件。您可以使用域的相对路径来引用它,例如'/file.css‘
Node会有更多的选择,因为它可以与内置的fs (文件系统)库同步地读取和访问本地文件。
你需要做的就是像对待互联网上的任何其他文件一样,以同样的方式下载它。然后,当您需要检查更新时,再次下载它。重复一遍。
https://stackoverflow.com/questions/53769338
复制相似问题