加入收藏 | 设为首页 | 会员中心 | 我要投稿 PHP编程网 - 黄冈站长网 (http://www.0713zz.com/)- 数据应用、建站、人体识别、智能机器人、语音技术!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

借助PHP和HTML5 FormData实现无刷新文件上传教程

发布时间:2022-07-18 14:34:41 所属栏目:PHP教程 来源:互联网
导读:这篇文章主要介绍了使用PHP和HTML5 FormData实现无刷新文件上传教程,本文先是分解了程序的编写步骤,最后给出一个完整示例,需要的朋友可以参考下 无刷新文件上传是一个常见而又有点复杂的问题,常见的解决方案是构造 iframe 方式实现。 那么 FormData 怎么使
  这篇文章主要介绍了使用PHP和HTML5 FormData实现无刷新文件上传教程,本文先是分解了程序的编写步骤,最后给出一个完整示例,需要的朋友可以参考下
 
  无刷新文件上传是一个常见而又有点复杂的问题,常见的解决方案是构造 iframe 方式实现。
 
  那么 FormData 怎么使用呢?下面脚本之家对此进行简单的介绍。
 
  1. 构造 FormData 对象
 
  想得到一个FormData对象,很简单:
 
  方法一:创建一个空的FormData对象,然后再用append方法逐个添加键值对。示例:
 
  var fd = new FormData();
  fd.append("name", "php粉丝网");
  fd.append("blog", "http://www.phpfensi.com");
  fd.append("file", document.getElementById("file"));
  这种方法可以不需要 HTML 的表单对象存在。
 
  方法二:取得form元素对象,将它作为参数传入FormData对象中,示例:
 
  var formobj = document.getElementById("form");
  var fd = new FormData(formobj);
  当然,这里还可以使用 append 方法继续向 fd 中添加其他参数。
 
  2. FormData 发送请求
 
  得到 FormData 对象了,如何发送请求呢? FormData 对象主要用于增强型的 XMLHttpRequest 对象的 send 方法中。参考如下示例:
 
  var xhr = new XMLHttpRequest();     
  xhr.open("POST" ,"http://jb51.net" , true);
  xhr.send(fd);
  xhr.onload = function(e) {
    if (this.status == 200) {
      alert(this.responseText);
    }
  };
  3. jquery 中使用 FormData
 
  在 jQuery 的 ajax 方法中,也可使用 FormData 方式实现无刷新上传。但要注意参数的设置,参考如下:
 
  $.ajax({
    url: "http://jb51.net",
    type: 'POST',
    data: fd,
    /**
     *必须false才会自动加上正确的Content-Type
     */
    contentType:false,
    /**
     * 必须false才会避开jQuery对 formdata 的默认处理
     * XMLHttpRequest会对 formdata 进行正确的处理
     */
   });
  4. 一个完整的示例(包含PHP处理示例):
 
  <?php
  //php 接收表单提交信息并打印
  if( isset( $_REQUEST['do']) ){
    var_dump($_REQUEST);
    var_dump($_FILES);
    die();
  }
   
  ?>
  <!DOCTYPE HTML>
  <html>
    <head>
      <meta charset="utf-8">
      <title>FormData Test - jb51.net</title>
      <script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
    </head>
    <body>
      <form id="form">
        <input type="file" name="file" id="file" />
        <input type="text" name="name" id="" value="脚本之家" />
        <input type="text" name="blog" id="" value="http://jb51.net" />
        <input type="submit" name="do" id="do" value="submit" />
      </form>
      <script>
      $("form").submit(function(e){
        e.preventDefault();
          
        //空对象然后添加
        var fd = new FormData();
        fd.append("name", "脚本之家");
        fd.append("blog", "http://jb51.net");
        fd.append("file", document.getElementById("file"));
        //fd.append("file", $(":file")[0].files[0]); //jQuery 方式
        fd.append("do", "submit");
          
        //通过表单对象创建 FormData
        var fd = new FormData(document.getElementById("form"));
        //var fd = new FormData($("form:eq(0)")[0]); //jquery 方式
          
             alert(this.responseText);
          };
        };
        return;
        //jQuery 方式发送请求
        $.ajax({
          type:"post",
          //url:"",
          data: fd,
          processData: false,
          contentType: false
        }).done(function(res){
          console.log(res);
        });
         //www.phfpensi.com
        return false;
      });
      </script>
    </body>
  </html> 

(编辑:PHP编程网 - 黄冈站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读