我开始使用优秀的 http://blueimp.github.io/jQuery-File-Upload/文件上传项目。
从documentation的文件处理选项部分看来,jquery.fileupload-process.js可以让我解析甚至修改文件的二进制数据(文件数组 - 应用了进程的结果和originalFiles与原始上传的文件)
(解析,或附加或加密或对其做某事)
但是对于我的生活,我似乎无法弄清楚数组中的实际文件数据在哪里,以便我可以在上传之前对其进行预处理。
数据数组的哪个部分中包含“something.pdf”二进制文件?以便我可以在上传之前对其进行解析和转换?
//FROM: jquery.fileupload-process.js
//The list of processing actions:
processQueue: [
{
action: 'log'
}
],
add: function (e, data) {
var $this = $(this);
data.process(function () {
return $this.fileupload('process', data);
});
originalAdd.call(this, e, data);
}
},
processActions: {
log: function (data, options) {
console.log(data.files[0]); //Is it here?
console.log(data); //Is it here?
console.log(data.files[data.index]); //Is it here?
console.log(data.files[data.index].name); //Is it here?
//where?
谢谢。
答案 0 :(得分:5)
访问当前处理文件的正确方法如下:
var file = data.files[data.index];
对于支持File API的浏览器,这是一个File对象。
要检索实际的文件数据,我们必须使用FileReader界面:
var fileReader = new FileReader();
fileReader.onload = function (event) {
var buffer = event.target.result;
// TODO: Do something with the ArrayBuffer containing the file's data
};
fileReader.readAsArrayBuffer(file);
答案 1 :(得分:3)
在@ Sebastian的答案基础上,解释在哪里放置FileReader以使用fileupload插件可能很有用。 (我会对@ Sebastian的回答发表评论,但在评论栏中没有空格。)
我已将此内容添加到流程操作中(使用readAsText
而不是readAsArrayBuffer
),如下所示:
alertText: function(data, options) {
var dfd = $.Deferred(),
file = data.files[data.index];
var fileReader = new FileReader();
fileReader.onload = function (event) {
var fileText = event.target.result;
alert('Text of uploaded file: '+ fileText);
};
fileReader.readAsText(file);
return dfd.promise();
}