乐趣区

Ajax请求后台数据

一、前期准备
安装好 XAMPP 软件,并运行起来。本文代码是基于 XAMPP 开发环境,XAMPP 是完全免费且易于安装的 Apache 发行版,其中包含 MariaDB、PHP 和 Perl。XAMPP 开放源码包的设置让安装和使用出奇容易。
二、前后台数据交互
前台部分其中“process.php?name=Herry”,向后台传递 name 数据
document.getElementById(“button”).addEventListener(“click”,function () {
var xhr = new XMLHttpRequest();
xhr.open(“GET”,”process.php?name=Herry”,true);
xhr.onreadystatechange=function () {
if(xhr.readyState==4&&xhr.status==200) {
var data = xhr.responseText;
console.log(data)
}
};
xhr.send();
})
后台 PHP 部分后台接收了 name 数值,并向前台返回了 ”GET: 你的名字是 ”. $_GET[‘name’]
<?php
if (isset($_GET[‘name’])) {
echo “GET: 你的名字是 ”. $_GET[‘name’];
}
?>
于是最后前台 console 里面得到:GET: 你的名字是 Herry
三、正常表单提交到 PHP 与 Ajax 方式提交
正常表单 GET 提交数据到 PHP
前台部分
<form action=”process.php” method=”GET”>
<input type=”text” name=”name”>
<input type=”submit” value=” 提交 ”>
</form>
后台 PHP 部分
<?php
if (isset($_GET[‘name’])) {
echo “GET: 你的名字是 ”. $_GET[‘name’];
}
?>
表单输入名字 Bucky,然后点击提交后,浏览器将数据打包后,传递给后台, 最后后台返回我们想要的数据 —-GET: 你的名字是 Bucky。整个过程中页面有刷新,数据点击提交后,页面跳转到这个网址 http://localhost/ajax/process…
Ajax 请求后台数据 GET
Ajax 异步请求数据,无需刷新页面。可以提高用户体验,较少网络数据的传输量。click 事件改成 submit 事件(表单应该用 submit 事件),然后取消默认事件。
前台部分
//Html 部分
<form id=”getForm”>
<input type=”text”name=”name” id=”name1″>
<input type=”submit”value=” 提交 ”>
</form>
//Javascript 部分
document.getElementById(“getForm”).addEventListener(“submit”,function(e){
e.preventDefault();// 阻止默认跳转事件
var name=document.getElementById(“name1”).value;// 获取输入的值
var xhr = new XMLHttpRequest();
xhr.open(“GET”,”process.php?name=”+name,true);
xhr.onreadystatechange=function () {
if (xhr.status == 200&&xhr.readyState == 4) {
var data = xhr.responseText;
console.log(data);
}
}
xhr.send();
})
后台 PHP 部分
<?php
if (isset($_GET[‘name’])) {
echo “GET: 你的名字是 ”. $_GET[‘name’];
}
?>
在表单输入 Bucky,点击提交,最后在 console 显示:GET: 你的名字是 Bucky。整个过程页面无刷新,有效提高页面性能。
正常表单 POST 提交数据到 PHP
与 GET 提交数据差不多前台部分
<form action=”process.php” method=”POST”>
<input type=”text” name=”name”>
<input type=”submit” value=” 提交 ”>
</form>
后台 PHP 部分
<?php
if (isset($_POST[‘name’])) {
echo “POST: 你的名字是 ”. $_POST[‘name’];
}
?>
表单输入名字 Bucky,然后点击提交后,浏览器将数据打包后,传递给后台, 最后后台返回我们想要的数据 —-POST: 你的名字是 Bucky。整个过程中页面有刷新,数据点击提交后,页面跳转到这个网址 http://localhost/ajax/process…。与 GET 方式提交不同的是,POST 方法数据并没有内嵌在 url 中,这样安全性比较高。
Ajax 请求后台数据 POST
POST 请求与 GET 主要有两点不同:
①post 请求一定要设置请求头的格式内容:
xhr.setRequestHeader(“Content-type”,”application/x-www-form-urlencoded”);
②post 请求参数放在 send 里面,即请求体
xhr.send(“name=”+name”);
前台部分
//HTML 部分
<form id=”postForm”>
<input type=”text”name=”name” id=”name2″>
<input type=”submit”value=” 提交 ”>
</form>
//Javascript 部分
document.getElementById(“postForm”).addEventListener(“submit”, function (e) {
e.preventDefault();
var name=document.getElementById(“name2”).value;
var params = “name=”+name;
var xhr = new XMLHttpRequest();
xhr.open(“POST”,”process.php”,true);
xhr.setRequestHeader(“Content-type”,”application/x-www-form-urlencoded”);
xhr.onreadystatechange=function () {
if(xhr.readyState==4&&xhr.status==200) {
var data = xhr.responseText;
console.log(data);
}
};
xhr.send(params);
})
后台 PHP 部分
<?php
if (isset($_POST[‘name’])) {
echo “POST: 你的名字是 ”. $_POST[‘name’];
}
?>
表单输入名字 Bucky,然后点击提交后,最后在 console 显示:POST: 你的名字是 Bucky。整个过程页面无刷新。
四、总结
1. 在不需要重新刷新页面的情况下,Ajax 通过异步请求加载后台数据,提高用户体验和页面性能。2.GET 参数通过 URL 传递,POST 放在 Request body 中,后者安全性比较高。

退出移动版