本文实例讲述了php使用html5 formdata对象提交表单操作。分享给大家供大家参考,具体如下:
这是html5中新增的一个api,他能以表单对象作为参数,自动的把表单的数据打包,当ajax发送数据时,发送这个formdata对象,以达到发送表单数据的目的。
创建:
参数是一个form节点对象
?
|
1
2
|
var fm = document.getelementbyid('formid');
var fd = new formdata(fm);
|
优点:
(1)在以往的ajax做post请求时,当提交的数据比较多时,需要拼接请求的字符串,如:k1=v1&k2=v2...,使用formdata对象时不需要这样,可以节省工作量,也防止人为拼写错误。
(2)formdata对象不仅可以读取表单的数据,也可以自行追加数据
?
|
1
|
fd.append(name,value);
|
案例:
效果图:
文件结构图:
10-formdata.html文件:
?
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
|
<!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>
|
?
|
1
2
3
4
5
6
7
|
<?php
/**
* 使用formdata提交表单
* @author webbc
*/
print_r($_post);
?>
|
希望本文所述对大家PHP程序设计有所帮助。
原文链接:https://blog.csdn.net/baochao95/article/details/52799761
相关文章
猜你喜欢
- ASP.NET本地开发时常见的配置错误及解决方法? 2025-06-10
- ASP.NET自助建站系统的数据库备份与恢复操作指南 2025-06-10
- 个人网站服务器域名解析设置指南:从购买到绑定全流程 2025-06-10
- 个人网站搭建:如何挑选具有弹性扩展能力的服务器? 2025-06-10
- 个人服务器网站搭建:如何选择适合自己的建站程序或框架? 2025-06-10
TA的动态
- 2025-07-10 怎样使用阿里云的安全工具进行服务器漏洞扫描和修复?
- 2025-07-10 怎样使用命令行工具优化Linux云服务器的Ping性能?
- 2025-07-10 怎样使用Xshell连接华为云服务器,实现高效远程管理?
- 2025-07-10 怎样利用云服务器D盘搭建稳定、高效的网站托管环境?
- 2025-07-10 怎样使用阿里云的安全组功能来增强服务器防火墙的安全性?
快网idc优惠网
QQ交流群
您的支持,是我们最大的动力!
热门文章
-
2025-05-29 51
-
2025-05-27 51
-
2025-05-29 50
-
2025-06-04 98
-
2025-05-29 21
热门评论



