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

相關文章
相關標籤/搜索