dropzone.js 中的模拟文件拖放和上传
Simulated file drop and upload in dropzone.js
我正在为包含 dropzone.js 元素的网页编写测试工具,我们称它为 myDropzone
,由 $('#my-dropzone')
元素表示。
问题:
我可以使用 javascript 模拟将可上传文件拖放到拖放区吗?
我认为(但我不确定)这可能需要类似的东西:
- 在 javascript 中创建类文件对象,然后
- 正在
myDropzone
上触发放置事件。
第 2 步很简单,但第 1 步涉及创建一个类似文件的对象(包含真实数据流?),一旦删除就可以实际上传。
我试过创建虚拟文件,例如 this,然后使用 myDropzone.addFile(...)
,但这不会产生可上传的文件,因为没有数据负载。
谢谢!
我能够做的是从 base64 编码文件(在本例中为图像)创建一个 Blob 文件并将其传递给 addFile(),因此它本质上是模拟删除文件。
dropZone.addFile(base64toBlob(base64FileData, 'image/png'));
其中 base64toBlob
是:
function base64toBlob(b64Data, contentType, sliceSize) {
contentType = contentType || '';
sliceSize = sliceSize || 512;
var byteCharacters = atob(b64Data);
var byteArrays = [];
for (var offset = 0; offset < byteCharacters.length; offset += sliceSize) {
var slice = byteCharacters.slice(offset, offset + sliceSize);
var byteNumbers = new Array(slice.length);
for (var i = 0; i < slice.length; i++) {
byteNumbers[i] = slice.charCodeAt(i);
}
var byteArray = new Uint8Array(byteNumbers);
byteArrays.push(byteArray);
}
var blob = new Blob(byteArrays, {type: contentType});
return blob;
}
我正在为包含 dropzone.js 元素的网页编写测试工具,我们称它为 myDropzone
,由 $('#my-dropzone')
元素表示。
问题:
我可以使用 javascript 模拟将可上传文件拖放到拖放区吗?
我认为(但我不确定)这可能需要类似的东西:
- 在 javascript 中创建类文件对象,然后
- 正在
myDropzone
上触发放置事件。
第 2 步很简单,但第 1 步涉及创建一个类似文件的对象(包含真实数据流?),一旦删除就可以实际上传。
我试过创建虚拟文件,例如 this,然后使用 myDropzone.addFile(...)
,但这不会产生可上传的文件,因为没有数据负载。
谢谢!
我能够做的是从 base64 编码文件(在本例中为图像)创建一个 Blob 文件并将其传递给 addFile(),因此它本质上是模拟删除文件。
dropZone.addFile(base64toBlob(base64FileData, 'image/png'));
其中 base64toBlob
是:
function base64toBlob(b64Data, contentType, sliceSize) {
contentType = contentType || '';
sliceSize = sliceSize || 512;
var byteCharacters = atob(b64Data);
var byteArrays = [];
for (var offset = 0; offset < byteCharacters.length; offset += sliceSize) {
var slice = byteCharacters.slice(offset, offset + sliceSize);
var byteNumbers = new Array(slice.length);
for (var i = 0; i < slice.length; i++) {
byteNumbers[i] = slice.charCodeAt(i);
}
var byteArray = new Uint8Array(byteNumbers);
byteArrays.push(byteArray);
}
var blob = new Blob(byteArrays, {type: contentType});
return blob;
}