使用FormData对象提交表单及上传图片

来源:互联网 发布:编写高质量javascript 编辑:程序博客网 时间:2024/05/20 06:55

转自:http://blog.csdn.net/fdipzone/article/details/38910553


FormData 对象,可以把form中所有表单元素的name与value组成一个queryString,提交到后台。在使用Ajax提交时,使用FormData对象可以减少拼接queryString的工作量。


使用FormData对象

1.创建一个FormData空对象,然后使用append方法添加key/value

[javascript] view plain copy
  1. var formdata = new FormData();  
  2. formdata.append('name','fdipzone');  
  3. formdata.append('gender','male');  

2.取得form对象,作为参数传入到FormData对象

[html] view plain copy
  1. <form name="form1" id="form1">  
  2. <input type="text" name="name" value="fdipzone">  
  3. <input type="text" name="gender" value="male">  
  4. </form>  
[javascript] view plain copy
  1. var form = document.getElementById('form1');  
  2. var formdata = new FormData(form);  

使用FormData提交表单及上传文件:

[html] view plain copy
  1. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">  
  2. <html>  
  3.  <head>  
  4.   <meta http-equiv="content-type" content="text/html; charset=utf-8">  
  5.   <title> FormData Demo </title>  
  6.   <script src="//code.jquery.com/jquery-1.11.0.min.js"></script>  
  7.   
  8.   <script type="text/javascript">  
  9.   <!--  
  10.     function fsubmit(){  
  11.         var data = new FormData($('#form1')[0]);  
  12.         $.ajax({  
  13.             url: 'server.php',  
  14.             type: 'POST',  
  15.             data: data,  
  16.             dataType: 'JSON',  
  17.             cache: false,  
  18.             processData: false,  
  19.             contentType: false  
  20.         }).done(function(ret){  
  21.             if(ret['isSuccess']){  
  22.                 var result = '';  
  23.                 result += 'name=' + ret['name'] + '<br>';  
  24.                 result += 'gender=' + ret['gender'] + '<br>';  
  25.                 result += '<img src="' + ret['photo']  + '" width="100">';  
  26.                 $('#result').html(result);  
  27.             }else{  
  28.                 alert('提交失敗');  
  29.             }  
  30.         });  
  31.         return false;  
  32.     }  
  33.   -->  
  34.   </script>  
  35.   
  36.  </head>  
  37.   
  38.  <body>  
  39.     <form name="form1" id="form1">  
  40.         <p>name:<input type="text" name="name" ></p>  
  41.         <p>gender:<input type="radio" name="gender" value="1">male <input type="radio" name="gender" value="2">female</p>  
  42.         <p>photo:<input type="file" name="photo" id="photo"></p>  
  43.         <p><input type="button" name="b1" value="submit" onclick="fsubmit()"></p>  
  44.     </form>  
  45.     <div id="result"></div>  
  46.  </body>  
  47. </html>  

server.php

[php] view plain copy
  1. <?php  
  2. $name = isset($_POST['name'])? $_POST['name'] : '';  
  3. $gender = isset($_POST['gender'])? $_POST['gender'] : '';  
  4.   
  5. $filename = time().substr($_FILES['photo']['name'], strrpos($_FILES['photo']['name'],'.'));  
  6.   
  7. $response = array();  
  8.   
  9. if(move_uploaded_file($_FILES['photo']['tmp_name'], $filename)){  
  10.     $response['isSuccess'] = true;  
  11.     $response['name'] = $name;  
  12.     $response['gender'] = $gender;  
  13.     $response['photo'] = $filename;  
  14. }else{  
  15.     $response['isSuccess'] = false;  
  16. }  
  17.   
  18. echo json_encode($response);  
  19. ?>  

0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 鼻塞有一个月了怎么办 感冒一直流清水鼻涕怎么办 孩子受凉流清水鼻涕怎么办 一遇冷空气就打喷嚏流鼻涕怎么办 打喷嚏鼻塞流清鼻涕怎么办 哺乳期鼻子不通气有鼻涕怎么办 宝宝热伤风流清鼻涕怎么办 哺乳期感冒流鼻涕怎么办最有效 小孩睡觉太晚了怎么办 孩子晚上睡觉不安稳怎么办 月子里宝宝睡觉不安稳怎么办 月子宝宝睡觉不安稳怎么办 孩子老是流黄鼻涕怎么办 孕妇流黄鼻涕怎么办速效办法 孕妇感冒流黄鼻涕怎么办 孕妇有黄痰和黄鼻涕怎么办 孕妇感冒了流黄鼻涕怎么办 怀孕感冒了怎么办鼻塞流鼻涕 怀孕初期感冒了怎么办鼻塞流鼻涕 怀孕9个月流鼻涕怎么办 怀孕5个月流鼻涕怎么办 小孩老是流黄鼻涕口臭怎么办 狗狗有食欲流黄鼻涕拉稀怎么办 小孩流黄鼻涕咳嗽怎么办 小狗感冒了一直打喷嚏怎么办 眼干眼屎多模糊怎么办 宝宝眼睛上火眼屎多怎么办 眼睛发干眼屎多怎么办 三个月宝宝眼睛流泪有眼屎怎么办 小孩眼睛流泪有眼屎怎么办 宝宝上火眼睛有好多眼屎怎么办 宝宝眼睛流泪还有眼屎怎么办? 新生儿眼睛上火眼屎多怎么办 铁耳屎在最里面怎么办 婴儿鼻屎特别深怎么办 鼻子干呼吸就疼怎么办 儿童鼻子里总有好多鼻屎怎么办 小孩鼻子里有鼻屎呼吸不通怎么办 鼻子不通通气鼻屎粘在鼻子怎么办 鼻子里面干燥长鼻屎怎么办 鼻孔里干的难受怎么办