主頁 > 知識庫 > 利用H5特性FormData實現(xiàn)不刷新文件上傳

利用H5特性FormData實現(xiàn)不刷新文件上傳

熱門標簽:Mysql連接數(shù)設置 銀行業(yè)務 電子圍欄 團購網(wǎng)站 阿里云 Linux服務器 服務器配置 科大訊飛語音識別系統(tǒng)

之前朋友說的不刷新上傳文件。最暴力的解決方案就是上網(wǎng)上搜各種JS庫,附帶多圖上傳,預覽,甚至是圖片處理等特技。那么如果不接觸第三方的庫,可不可以利用ajax來做。就這個問題,有人給出的解決方案是借助iframe,這里就不贅述了。但是Html5是個好東西,他提供了FormData,F(xiàn)ormData可以幫助我們拼湊參數(shù),乃至文件資源。這樣,我們就可以輕松用$.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

 

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


您可能感興趣的文章:
  • vuejs開發(fā)組件分享之H5圖片上傳、壓縮及拍照旋轉的問題處理
  • H5上傳本地圖片并預覽功能
  • H5手機端多文件上傳預覽插件
  • 移動端利用H5實現(xiàn)壓縮圖片上傳功能
  • vue中用H5實現(xiàn)文件上傳的方法實例代碼
  • H5移動端圖片壓縮上傳開發(fā)流程
  • H5圖片壓縮與上傳實例
  • H5移動開發(fā)Ajax上傳多張Base64格式圖片到服務器
  • H5實現(xiàn)手機拍照和選擇上傳功能

標簽:蚌埠 棗莊 廣元 江蘇 衢州 衡水 大理 萍鄉(xiāng)

巨人網(wǎng)絡通訊聲明:本文標題《利用H5特性FormData實現(xiàn)不刷新文件上傳》,本文關鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266