php上传图片不刷新表单,H5特性之FormData不刷新文件上传

杂言

之前朋友说的不刷新上传文件。最暴力的解决方案就是上网上搜各种JS库,附带多图上传,预览,甚至是图片处理等特技。那么如果不接触第三方的库,可不可以利用ajax来做。就这个问题,有人给出的解决方案是借助iframe,这里就不赘述了。但是Html5是个好东西,他提供了FormData,FormData可以帮助我们拼凑参数,乃至文件资源。这样,我们就可以轻松用$.ajax不刷新上传。当然也不需要iframe。

代码

下列是前端部分。

$(function(){

$('#add').submit(function(){

var data = new FormData($('#add')[0]);

console.log(data);

$.ajax({

url: 'ajax.php',

type: 'POST',

data: data,

dataType: 'JSON',

cache: false,

processData: false,

contentType: false,

success:function(data){

//alert(data);

alert("UploadFile Success");

}

});

return false;

});

});

不多赘述里面的代码,就讲一行代码

var data = new FormData($('#add')[0]);

FormData是一个表单对象,他可以将表单对象的表单域分别形成key=>value。那么是不是我们自己再拼接额外的key=>value呢,答案是可以的,详情可以百度FormData。

还有就是为什么是$('#add')[0]?

我只能说 js = jQuery[0];

PHP部分

header('Content-Type:application/json; charset=utf-8');

echo json_encode(array($_FILES,$_REQUEST));

?>

这边只是做下测试,如果能看到$_FILES有东西,那么证明我们是可以做上传的。

测试上传

可以看到ajax请求到了ajax.php

bVmuEB

看下preview,就可以看到返回$_FILES的相关信息了。

bVmuEG

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值