我希望将上传文件的内容读入Javascript变量。
该程序曾使用file.getAsBinary工作,但现在不推荐使用,需要更新才能使用FileReader()
表单有文件上传选择,onsubmit在javascript中运行函数uploadDB()。
变量dbname传递正常,因为上传选择中的文件名也是如此 我可以通过alert或console.log看到它。
接收文件文本的最终bfile变量未定义。我已经尝试了readAsText和ReadAsBinary,但是bfile未定义。 var声明在函数uploadDB()中,并且应该是内部函数的全局。如果范围在某种程度上是一个问题,我如何在bfile变量中得到结果。
它可能很简单,但我无法让它工作。有人可以提出一些建议。 html部分是;
<form onsubmit="uploadDB()"; method="post">
Database <input type=text name="dbName" id="dbName" size=20>
<input type=file id="metaDescFile" size=50 >
<input type=submit value="Submit">
</form>
js脚本类似于(编辑出无关的东西);
<script language="javascript" type="text/javascript">
<!--
var uploadDB = function() {
var input = document.getElementById('metaDescFile');
var fname = document.getElementById('metaDescFile').value;
var file=input.files[0];
var bfile;
reader = new FileReader();
reader.onload = function(e) { bfile = e.target.result }
reader.readAsText(file);
alert(bfile); // this shows bfile as undefined
// other stuff
}
答案 0 :(得分:5)
因为在onload
回调中设置了bfile,你将无法在回调之外访问,因为在回调被触发之前会对代码进行评估。
试试这个:
reader = new FileReader();
reader.onload = function(e) {
bfile = e.target.result
alert(bfile); // this shows bfile
}
reader.readAsText(file);