jquery ajax上传表单序列化

时间:2012-01-28 13:06:56

标签: jquery ajax upload

我在从html表单上传图片时遇到了一些困难。 当有人点击某个项目时,表单会添加到div中,以下是代码:

$("#editavatar").click(function(){
    $(".rightdisplay").html('<form class="upload" method="post" enctype="multipart/form-data">');
    $(".rightdisplay").append('<div class="editavatar"></div>');
    $(".rightdisplay .editavatar").append('<div class="boxtitle">edit avatar</div>');
    $(".rightdisplay .editavatar").append('<div class="boxwrapm"><input type="file" name="imageup" id="imageup" value="" /></div>');
    $(".rightdisplay .editavatar").append('<div class="boxwrapm"><input type="submit" name="submit" class="imageupload" value="Send" /></div>');
    $(".rightdisplay .editavatar").append('</form>');
    Cufon.replace('.boxtitle');
});

表单是否正确创建,问题是当我尝试在单击提交按钮时序列化表单时,dataString变量保持为空:

$(document).on("click", "input.imageupload", function(event){
    event.preventDefault();
    dataString = $("form.upload").serialize();
    alert(dataString);
    $.ajax({
        type: "POST",
        url: "http://xxx/upload.php",
        data: dataString,
        dataType: "json",
        success: function(json){
            if(json.jresponse==true){
                $(".avatar").css({"background" : "url(http://xxx/images/avatars/"+json.juser+".png) #000000 center center no-repeat;"});
            }
            alert(json.jmessage);
        },
        error: function(xhr, textStatus, errorThrown){
            alert(errorThrown);
        }
    });
    return false;
});

为什么不序列化?

2 个答案:

答案 0 :(得分:3)

ajax无法上传文件,jquery不会序列化文件输入字段,另请参阅http://api.jquery.com/serialize/

答案 1 :(得分:0)

如果要上传包含表单数据的文件,需要包含以下js文件:

<script src="http://malsup.github.com/jquery.form.js"></script>

在任何事件中使用以下代码:

var options = { 
  url: url,
data : {'username' : username, 'password' :     password ,'repeatpassword' :repeatpassword,'firstname' :firstname,'lastname' :lastname,'email' :email},
success:function(data) { 
    alert(data);    
  } 
}; 

$('#formId').ajaxForm(options);