手机
当前位置:查字典教程网 >编程开发 >AJAX相关 >利用H5特性FormData实现不刷新文件上传
利用H5特性FormData实现不刷新文件上传
摘要:之前朋友说的不刷新上传文件。最暴力的解决方案就是上网上搜各种JS库,附带多图上传,预览,甚至是图片处理等特技。那么如果不接触第三方的库,可不...

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

代码

下列是前端部分。

<!DOCTYLE html> <meta charset=utf-> <head> <script type="text/javascript" src="http://apps.bdimg.com/libs/jquery/../jquery.min.js"></script> </head> <script type="text/javascript"> $(function(){ $('#add').submit(function(){ var data = new FormData($('#add')[]); 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; }); }); </script> <form id='add'> <input type="text" name='book'></input> <input type="file" name='source'></input> <input type="submit"> </form>

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

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

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

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

我只能说 js = jQuery[0];

PHP部分

<?php header('Content-Type:application/json; charset=utf-8'); echo json_encode(array($_FILES,$_REQUEST)); ?>

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

测试上传

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

利用H5特性FormData实现不刷新文件上传1

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

利用H5特性FormData实现不刷新文件上传2

【利用H5特性FormData实现不刷新文件上传】相关文章:

利用 Linq+Jquery+Ajax 实现异步分页功能可简化带宽压力

基于ajax的简单搜索实现方法

基于ajax实现无刷新分页的方法

IE8用ajax访问不能每次都刷新的问题

使用$.getJSON实现跨域ajax请求示例代码

5款Ajax 文件上传控件

利用ajax实现简单的注册验证局部刷新实例

PHP Ajax实现页面无刷新发表评论

jsp+ajax实现无刷新上传文件的方法

Ajax实现跨域访问的三种方法

精品推荐
分类导航