关于ajax提交表单的问题

对于ajax的写法都差不多的有几种写法,比如:

$.post(path,{data:data},function(data){
    ...
},"json");
$.ajax({
         url:"${pageContext.request.contextPath}/public/testupload",
          type:"post",
          data:{username:username},
          success:function(data){
              window.clearInterval(timer);
              console.log("over..");
          },
          error:function(e){
              alert("错误!!");
              window.clearInterval(timer);
          }
      });    

但是如果提交的同时有上传的文件或者图片,这些方式就不行了,一般都是采用表单提交的方式,但是习惯了ajax的提交就可以用FormData,它是一个html5的javascript对象,非常的强大。
只需要在js中获取你要提交表单的对象:

var form = new FormData(document.getElementById("tf"));//tf是form表单的id

或者往对象里面装填你需要的数据:

var form = new FormData();
form.append("username","zxj");
form.append("password",123456)

大概最后的写法就是这样了:

function test(){
            var form = new FormData(document.getElementById("tf"));
            $.ajax({
                url:"url",
                type:"post",
                data:form,
                processData:false,
                contentType:false,
                success:function(data){
                    ...
                },
                error:function(e){
                    alert("错误!!");
                }
            });        
            get();//此处为上传文件的进度条
        }

就是这么简单,使用FormData,在构造这个对象的时候,把表单的对象,作为一个参数放进去,就可以了,然后FormData,就会得到这个表单对象里面的所有的参数,甚至我们在表单中,都不需要声明enctype =”multipart/form-data” ,就可以直接提交。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值