使用javascript读取本地文本文件

新手上路,请多包涵

我想从我的本地 html 文件中读取本地文本文件,所以我尝试按照此线程 Javascript 中的解决方案 - 读取本地文本文件,但建议的解决方案对我也不起作用:

 function readTextFile(file)
{
    var rawFile = new XMLHttpRequest();
    rawFile.open("GET", file, false);
    rawFile.onreadystatechange = function ()
    {
        if(rawFile.readyState === 4)
        {
            if(rawFile.status === 200 || rawFile.status == 0)
            {
                var allText = rawFile.responseText;
                alert(allText);
            }
        }
    }
    rawFile.send(null);
}

当我调用函数 readTextFile("file:///D:/test/text.txt"); 萤火虫中没有出现任何错误,但也没有显示任何警报。我使用 Windows 和 Firefox 51.0.1(64 位)。我不想将功能 FileReader() 与按钮结合使用 <input type='file' onchange='openFile(event)' ... 因为加载页面时需要自动读取文本文件。那么我怎样才能使上面的解决方案起作用呢?

阅读链接的线程,尽管该线程被标记为已解决,但看起来其他人对该解决方案也有问题。

原文由 Markus 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 214
1 个回答

以完整的 HTML 和 JavaScript 文件为例,读取客户端数据文件。客户端文件只能由 FileReader 访问,指定用户选择的文件。

 <!DOCTYPE html>
<html>
    <head>
        <script type="text/javascript">
                function loadFile(o)
                {
                    var fr = new FileReader();
                    fr.onload = function(e)
                        {
                            showDataFile(e, o);
                        };
                    fr.readAsText(o.files[0]);
                }

                function showDataFile(e, o)
                {
                    document.getElementById("data").innerText = e.target.result;
                }
            </script>

        </script>
    </head>
    <body>
        Select file to read <input type="file" onchange="loadFile(this)">
        <pre id="data"></pre>
    </body>
</html>

原文由 Balazs Vago 发布,翻译遵循 CC BY-SA 3.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
logo
Stack Overflow 翻译
子站问答
访问
宣传栏