使用jquery异步上传文件的操作

Adi*_*ote 6 javascript ajax upload jquery asynchronous

我想使用jQuery异步上传文件.这是我的HTML:

<input type="file" id="f" name="f"/>
<input id="upload" type="button" value="Upload"/>
Run Code Online (Sandbox Code Playgroud)

在这里我的JavaScript代码:

$(document).ready(function () {
$("#upload").click(function () {
    var filename = $("#f").val();

    $.ajax({
        type: "POST",
        url: "addFile.do",
        enctype: 'multipart/form-data',
        data: {
            file: filename
        },
        success: function () {
            alert("All Files Have Been Uploaded ");
        }
    });
});
});
Run Code Online (Sandbox Code Playgroud)

我只获取文件名而不是我上传的实际文件

我正在使用此插件上传文件.

Ant*_*ala 1

与您想象的不同,代码不使用该插件来上传文件。相反,您显式发出 ajax 请求。发生错误的原因是 的值<input type="file">是文件名,并且这是您在请求中发送的唯一数据。

相反,您需要使用 ; 绑定表单$(form).ajaxform()。然后在单击处理程序中,您可以触发表单上的提交事件。

因此,像下面这样的东西应该可以解决问题:

html:

<form method="post" action="addFile.do">
<input type="file" id="f" name="f"/>
<input id="upload" type="button" value="Upload"/>
</form>
Run Code Online (Sandbox Code Playgroud)

和 JavaScript:

$('form').ajaxform({
    success: function () {
        alert("All Files Have Been Uploaded ");
    }
});

$("#upload").click(function() {
    $('form').submit();
});
Run Code Online (Sandbox Code Playgroud)