H5特性之FormData不刷新文件上传

杂言

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

代码

下列是前端部分。php

<!DOCTYLE html>
<meta charset=utf-8>
<head>
<script type="text/javascript" src="http://apps.bdimg.com/libs/jquery/2.1.1/jquery.min.js"></script>
</head>


<script type="text/javascript">
$(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;   
    });
    
});
</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]);html

FormData是一个表单对象,他能够将表单对象的表单域分别造成key=>value。那么是否是咱们本身再拼接额外的key=>value呢,答案是能够的,详情能够百度FormData前端

还有就是为何是$('#add')[0]?
我只能说 js = jQuery[0];java

PHP部分jquery

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

这边只是作下测试,若是能看到$_FILES有东西,那么证实咱们是能够作上传的。ajax

测试上传

能够看到ajax请求到了ajax.php
clipboard.pngjson

看下preview,就能够看到返回$_FILES的相关信息了。
clipboard.pngapp

相关文章
相关标签/搜索