概念:#
1. ASynchronous JavaScript And XML 异步的JavaScript和XML.
2. AJAX不是新的编程语言,而是一种使用现有标准的新方法.
3. AJAX是与服务器交换数据并更新部分网页的技术,在不重新加载整个页面的情况下.
4. 异步和同步(客户端和服务器端相互通信的基础上):
客户端必须等待服务器端的响应。在等待的期间客户端不能做其他操作。
客户端不需要等待服务器端的响应。在服务器处理请求的过程中,客户端可以进行其他的操作。
实现方式:#
1.原生实现方式#
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>原生的JS实现方式</title>
<script>
function fun(){
var xmlhttp;
if (window.XMLHttpRequest)
{
xmlhttp=new XMLHttpRequest();
}
else
{
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","ajaxServlet?username=hzc",true);
xmlhttp.send();
xmlhttp.onreadystatechange=function()
{
if (xmlhttp.readyState==4 && xmlhttp.status==200)
{
let responseText = xmlhttp.responseText;
alert(responseText);
}
}
}
</script>
</head>
<body>
<button onclick="fun()">发送异步请求</button>
</body>
</html>
2.JQuery实现方式#
1.$.ajax()
语法:$.ajax({键值对});
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>JQ $.ajax()实现方式</title>
<script src="js/jquery-3.3.1.min.js"></script>
<script>
function fun() {
$.ajax({
url:"ajaxServlet",
type:"POST",
data:{"username":"hzc"},
success:function (data) {
alert(data);
},
error:function () {
alert("error!");
},
dataType:"text"
});
}
</script>
</head>
<body>
<button onclick="fun()">发送异步请求</button>
</body>
</html>
2.$.get()和$.post()
语法:
$.get(url.[data],[callback],[type]);
url:请求路径
data:请求参数
callback:回调函数
type:响应结果类型
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="js/jquery-3.3.1.min.js"></script>
<script>
function fun() {
$.get("ajaxServlet",{username:"hzc"},function (data) {
alert(data);
},"text");
}
</script>
</head>
<body>
<button onclick="fun()">发送异步请求</button>
</body>
</html>
服务器端Servlet#
package com.servlet;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
@WebServlet("/ajaxServlet")
public class AjaxServlet extends HttpServlet {
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
String username = req.getParameter("username");
System.out.println(username);
resp.getWriter().write(username);
}
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
this.doPost(req, resp);
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理