• 技术文章 >后端开发 >php教程

    前端使用formdata异步上传form表单,以及后台(php)获取的详细教程,亲测可用.(附要源码)

    不言不言2018-04-18 15:53:02原创8242

    这篇文章主要介绍了前端使用formdata异步上传form表单,以及后台(php)获取的详细教程,亲测可用.(附要源码),有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下

    前端如果要异步提交一个表单那么,使用formdata方法提交是不错的选择.因为formdata可以将整个表单都提交包括提交表单中的

    文件(这个是重点,很多其他方式不能完成).

    前端的关键部分代码如下:

    <form id="form"  method="post" enctype="multipart/form-data">
    <input type="text" name="name" />
    <input type="file" name=img />
    <input type="button" onclick="submit()"/>
    </form>
    <script>
    function submit(){
    
    var myform  = document.getElementById("form")
    var formfile = new FormData(myform);
    var author = ["sony", "god", "JB"];
    formfile.append("author",  author);    //此处是在原表单上在增加一些字段, 后端用$_POST["author"]就可以取得相应的值
    var xml = new XMLHttpRequest();
    xml.onreadystatechange =  function(){
            if(xml.readyState == 4 &&  xml.status == 200){
                    var result = JSON.parse(xml.responseText);
                   console.log(result) //在打印台就可以看到相应的表单值
            }
    }
    xml.open("POST",  "你要提交到那个服务器地址", true);
    xml.send( formfile );
    }
    </script>


    后台使用php,其他的语言可以参考思路是一样的 get.php

    <?php 
    $name = $_POST["name"];
    $author = $_POST['author"];
    $file = $_FILES["img"];
    move_uploaded_file($file['tmp_name'], $file["name"]);  //上传到和get.php同一级目录的服务器上
    //至此,前端异步上传的name 和author 和 img 都已经取到.后续可以根据自己的需要去做其他事情
    ?>

    遇到的坑:

    如form.file.append("author", author)可以额外增加自己想要上传的值,但是author 数值和数组和字符串亲测可用,但是如果你是想要 增加个表单那是不行如 formfile.append("form", form) 在后台$_POST["form"]得到是 fromElementobject



    以上就是前端使用formdata异步上传form表单,以及后台(php)获取的详细教程,亲测可用.(附要源码)的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:formdata php 上传
    上一篇:php正则只保留汉字 字母 数字 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • 一文详解PHP用流方式实现下载文件(附代码示例)• PHP反序列化入门总结(小白必看)• PHP原生类的总结分享• 聊聊PHP escapeshellarg函数使用的中文问题• 分享PHP函数使用小工具(附代码示例)
    1/1

    PHP中文网