我想通过JavaScript(非框架)上传图像。有人有如何做到这一点的基本例子吗?
我收到这个错误消息:
警告:第0行未知数组()中的多部分/表单数据POST数据中缺少边界
以下是我目前正在进行的工作。
<form action="" method="" enctype="" id="uploadImage">
<input type="file" name="image1" id="image1" value="" >
<input type="button" id="submit_button" data-data_enctype="multipart/form-data" data-form_name="uploadImage" data-url="/gallery/images/upload/" data-change_div="getForm" value="Upload" onclick="image(this.id, form.id)"/>
</form>
var xmlhttp;
if (window.XMLHttpRequest)
{
xmlhttp = new XMLHttpRequest();
}
else
{
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
var datVar = document.getElementById(id);
var url = datVar.dataset.url;
var change_div = datVar.dataset.change_div;
xmlhttp.onreadystatechange = function()
{
if (xmlhttp.readyState == 4 && xmlhttp.status == 200)
{
document.getElementById(change_div).innerHTML = xmlhttp.responseText;
}
}
xmlhttp.open("POST", url, true);
xmlhttp.setRequestHeader("Content-type", "multipart/form-data");
xmlhttp.send('NULL');
您需要将要发送的数据传递给xmlhttp.send()方法。当前您正在将其传递为"NULL",因此它会抱怨数据丢失。
类似于var data = document.getElementById('#uploadImage');
获取表单。创建FormData对象(FormData仅在现代浏览器中受支持)var formData = new FormData(data);
然后将formData
传递给发送方法就可以了。