使用FormData对象提交表单

13 篇文章 0 订阅
9 篇文章 0 订阅

这是HTML5中新增的一个Api,他能以表单对象作为参数,自动的把表单的数据打包,当ajax发送数据时,发送这个FormData对象,以达到发送表单数据的目的。

创建:
参数是一个form节点对象

var fm = document.getElementById('formid');
var fd = new FormData(fm);

优点:
(1)在以往的ajax做post请求时,当提交的数据比较多时,需要拼接请求的字符串,如:k1=v1&k2=v2...,使用FormData对象时不需要这样,可以节省工作量,也防止人为拼写错误。

(2)FormData对象不仅可以读取表单的数据,也可以自行追加数据

fd.append(name,value);

案例:
提交表单

效果图:
这里写图片描述

文件结构图:
这里写图片描述

10-formdata.html文件:

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>FormData使用</title>
    <link rel="stylesheet" href="">
</head>
<script>
    /**
     * FromData:表单数据对象
     * 这是HTML5中新增的一个Api
     * 他能以表单对象作为参数,自动的把表单的数据打包
     * 当ajax发送数据时,发送这个formData
     * 达到发送表单内数据的目的
     */
    function send(){
        var fm = document.getElementById('tform');
        var fd = new FormData(fm);//创建FormData对象
        var xhr = new XMLHttpRequest();//创建xhr对象
        xhr.open('POST','10-formdata.php',true);//配置请求参数
        //设置状态回调函数
        xhr.onreadystatechange = function (){
            if(this.readyState == 4 && this.status == 200){
                document.getElementById('debug').innerHTML = this.responseText;
            }
        }
        //说明formdata对象不仅可以读取表单的数据,也可以自行追加数据
        fd.append('Single',false);
        xhr.send(fd);//发送请求
    }

</script>
<body>
    <form id="tform">
        用户名:<input type="text" name="username"/><br/>
        年龄:<input type="text" name="age"/><br/>
        邮箱:<input type="text" name="email"/><br/>
        性别:<input type="text" name="sex"/><br/>
        <input type="button" value="ajax发送" onclick="send();"/>
    </form>
    <div id="debug"></div>
</body>
</html>

10-formdata.php文件:

<?php
/**
 * 使用formData提交表单
 * @author webbc
 */
print_r($_POST);
?>
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值