使用FormData提交表單及上傳圖片的方法

一个新手
發布: 2017-09-14 10:52:14
原創
2352 人瀏覽過

FormData 對象,可以把form中所有表單元素的name與value組成一個queryString,提交到後台。在使用Ajax提交時,使用FormData物件可以減少拼接queryString的工作量。


使用FormData物件

#1.建立一個FormData空對象,然後使用append方法新增key/value


  1. var# formdata = new # FormData();  

  2. #formdata.append('name',#' fdipzone');  

  3. #formdata.append('gender'#,'male');  

#2.取得form對象,並將其作為參數傳入至FormData物件

#
    <form name="form1" id="form1">  
    <input type="text" name="name" value="fdipzone">  
    <input type="text" name="gender" value="male">  
    </form>
登入後複製



  1. var form = document.getElementById(&#39;form1&#39;);  
    var formdata = new FormData(form);
    登入後複製

使用FormData提交表單及上傳檔案:


  1. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">  
    <html>  
     <head>  
      <meta http-equiv="content-type" content="text/html; charset=utf-8">  
      <title> FormData Demo </title>  
      <script src="//code.jquery.com/jquery-1.11.0.min.js"></script>  
      
      <script type="text/javascript">  
      <!--  
        function fsubmit(){  
            var data = new FormData($(&#39;#form1&#39;)[0]);  
            $.ajax({  
                url: &#39;server.php&#39;,  
                type: &#39;POST&#39;,  
                data: data,  
                dataType: &#39;JSON&#39;,  
                cache: false,  
                processData: false,  
                contentType: false  
            }).done(function(ret){  
                if(ret[&#39;isSuccess&#39;]){  
                    var result = &#39;&#39;;  
                    result += &#39;name=&#39; + ret[&#39;name&#39;] + &#39;<br>&#39;;  
                    result += &#39;gender=&#39; + ret[&#39;gender&#39;] + &#39;<br>&#39;;  
                    result += &#39;<img src="&#39; + ret[&#39;photo&#39;]  + &#39;" width="100">&#39;;  
                    $(&#39;#result&#39;).html(result);  
                }else{  
                    alert(&#39;提交失敗&#39;);  
                }  
            });  
            return false;  
        }  
      -->  
      </script>  
      
     </head>  
      
     <body>  
        <form name="form1" id="form1">  
            <p>name:<input type="text" name="name" ></p>  
            <p>gender:<input type="radio" name="gender" value="1">male <input type="radio" name="gender" value="2">female</p>  
            <p>photo:<input type="file" name="photo" id="photo"></p>  
            <p><input type="button" name="b1" value="submit" onclick="fsubmit()"></p>  
        </form>  
        <p id="result"></p>  
     </body>  
    </html>
    登入後複製

#server.php


server.php

########
<?php  
$name = isset($_POST[&#39;name&#39;])? $_POST[&#39;name&#39;] : &#39;&#39;;  
$gender = isset($_POST[&#39;gender&#39;])? $_POST[&#39;gender&#39;] : &#39;&#39;;  
  
$filename = time().substr($_FILES[&#39;photo&#39;][&#39;name&#39;], strrpos($_FILES[&#39;photo&#39;][&#39;name&#39;],&#39;.&#39;));  
  
$response = array();  
  
if(move_uploaded_file($_FILES[&#39;photo&#39;][&#39;tmp_name&#39;], $filename)){  
    $response[&#39;isSuccess&#39;] = true;  
    $response[&#39;name&#39;] = $name;  
    $response[&#39;gender&#39;] = $gender;  
    $response[&#39;photo&#39;] = $filename;  
}else{  
    $response[&#39;isSuccess&#39;] = false;  
}  
  
echo json_encode($response);  
?>
登入後複製
######################

以上是使用FormData提交表單及上傳圖片的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板