我有个文本文件 cellphone.txt ,有三行内容
iPhone
Pixel
Windows Phone
在HTML文件中,我利用按钮(button)的onclick时间去触发下文中的 js 脚本中包含的函数 startOutput(),这个函数中先创建一个 id 为 outputStream 的段落,然后用 nodejs 里的 readline 模块按行读取 cellphone.txt 文件中的内容,每读取一行就更新到 outputStream 中去,实现顺序显示文件每行内容。但实际运行的时候,并不是依次显示 iPhone ,然后 Pixel ,最后再是 Windows Phone ,而是卡一阵子,然后 outputStream 段落中只显示最后一行内容 Windows Phone 。当然,你可能会说由于你这里只有三行,依次显示的速度太快了,你没看到前两次输出。换成一个拥有1000行内容的文本文件,效果也是卡一阵子,然后只输出最后一行。
HTML 文件:
<html>
<body>
<script src='output.js'></script>
<button type="button" onclick="startOutput()"></button>
</body>
</html>
JavaScript 文件:
//output.js
function startOutput() {
document.write('<p id="outputStream">初始文本<p>');
var fs = require('fs');
var lineReader = require('readline').createInterface({
input: fs.createReadStream('cellphone.txt') // 建立 txt 文件的读取流
});
lineReader.on('line', function (line) { //按行对读取流内容进行操作
document.getElementById("outputStream").innerHTML(line);
}
}
这里并不一定非要用button去触发这个函数。我的主要目的是在 html 页面中,按行显示文件内容(必须要有显示过程,先第一行,再第二行,然后以此类推),如果有其他方法可以实现这一点,欢迎 V 友提出,感谢大家!
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.