Ajax 请求后台数据

发布于 2023-10-25 21:59:17 字数 4605 浏览 35 评论 0

一、前期准备

安装好 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.php?name=Bucky

Ajax 请求后台数据 GET

Ajax 异步请求数据,无需刷新页面。可以提高用户体验,较少网络数据的传输量。click 事件改成 submit 事件(表单应该用 submit 事件),然后取消默认事件。

前台部分

//Html 部分
<form>
    <input type="text"name="name">
    <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.php 。与 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>
    <input type="text"name="name">
    <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 中,后者安全性比较高。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

0 文章
0 评论
23 人气
更多

推荐作者

内心激荡

文章 0 评论 0

JSmiles

文章 0 评论 0

左秋

文章 0 评论 0

迪街小绵羊

文章 0 评论 0

瞳孔里扚悲伤

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文