如何从一个txt文件中读取文本,只需一个按钮即可浏览文件,另一个按钮可以显示文本。请帮助我获取代码。我尝试了很多代码,但没有任何效果。一些代码是这样的。提前致谢
<!DOCTYPE html>
<html>
<head>
<title>reading file</title>
<script type="text/javascript">
var reader = new FileReader();
function readText(that){
if(that.files && that.files[0]){
var reader = new FileReader();
reader.onload = function (e) {
var output=e.target.result;
//process text to show only lines with "@":
output=output.split("\n").filter(/./.test, /\@/).join("\n");
document.getElementById('main').innerHTML= output;
};//end onload()
reader.readAsText(that.files[0]);
}//end if html5 filelist support
}
</script>
</head>
<body>
<input type="file" onchange='readText(this)' />
<div id="main"></div>
</body>
</html>
答案 0 :(得分:1)
你应该正确阅读这样的文章:http://www.html5rocks.com/en/tutorials/file/dndfiles/
不要认为这条线工作正常:
output=output.split("\n").filter(/./.test, /\@/).join("\n");
尝试将其更改为:
output=output.split("\n").filter(function(l) {
//return /^\@/.test(l); // Starting with @
return l.indexOf('@') > -1; // Containing @
}).join("\n");
看看这是否会起作用会很有趣:
output=output.split("\n").filter(/\@/.test.bind(/\@/)).join("\n");
传递给.filter
方法的第二个参数是上下文:
array.filter(callback [,thisObject])
答案 1 :(得分:0)
获取输入文件,使用FileReader()读取它,在文件加载时获取与模式匹配的文本。最后通过“main”div显示它。应该工作..
HTML:
<input id="fileInput" type="file"/>
<div id="main"></div>
jQuery:
$(function(){
$("#fileInput").change(function(e){
var myFile = e.target.files[0];
var reader = new FileReader();
reader.onload = function(e){
var output = e.target.result;
output=output.split("\n").filter(/./.test, /\@/).join("\n");
$("#main").text(output);
};
reader.readAsText(myFile)
});
}
)