Javascript图像上传(非框架)


Javascript image upload (Non framework)

我想通过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传递给发送方法就可以了。