AJAX快速入门 - 四个核心步骤

1. 编写AjaxServlet,并使用response输出字符串

这是服务器端的工作:

  • 创建一个Java Servlet来处理AJAX请求
  • 当服务器收到请求后,通过response输出字符串返回给客户端
  • 比如:返回"Hello World"或JSON数据

2. 创建XMLHttpRequest对象(代码不用背,直接复制就行了)

这是客户端的第一步,用于和服务器交换数据:

java 复制代码
var xmlhttp;
if (window.XMLHttpRequest) {
    // 现代浏览器:IE7+, Firefox, Chrome, Opera, Safari
    xmlhttp = new XMLHttpRequest();
} else {
    // 老版本IE浏览器
    xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}

为什么需要兼容性检查?

  • 现代浏览器都支持XMLHttpRequest
  • 老版本IE浏览器需要使用ActiveXObject

3. 向服务器发送请求(这里面的url用完整路径,因为开发是前后端分离)

java 复制代码
xmlhttp.open("GET","url");  // 打开GET请求到指定URL
xmlhttp.send();            // 发送请求

4. 获取服务器响应数据

java 复制代码
xmlhttp.onreadystatechange = function () {
    if (xmlhttp.readyState == 4 && xmlhttp.status == 200){
        alert(xmlhttp.responseText);  // 显示服务器返回的数据
    }
}

关键概念:

  • readyState == 4:请求完成
  • status == 200:请求成功
  • responseText:服务器返回的文本内容

完整流程图示

客户端(浏览器) → 请求 → 服务器(Servlet)

客户端(浏览器) ← 响应 ← 服务器(Servlet)

实际应用例子

比如用户点击一个按钮,想要检查用户名是否可用:

  1. 用户点击按钮
  1. JavaScript创建XMLHttpRequest
  1. 发送请求到服务器:"检查用户名'张三'"
  1. 服务器处理:查询数据库
  1. 返回结果:"用户名已存在"
  1. JavaScript接收:显示"用户名已被使用"

这就是AJAX的完整工作流程!

相关推荐
军军君0130 分钟前
Three.js基础功能学习十三:太阳系实例上
前端·javascript·vue.js·学习·3d·前端框架·three
xiaoqi9221 小时前
React Native鸿蒙跨平台如何实现分类页面组件通过searchQuery状态变量管理搜索输入,实现了分类的实时过滤功能
javascript·react native·react.js·ecmascript·harmonyos
打小就很皮...2 小时前
Tesseract.js OCR 中文识别
前端·react.js·ocr
qq_177767372 小时前
React Native鸿蒙跨平台实现应用介绍页,实现了应用信息卡片展示、特色功能网格布局、权限/联系信息陈列、评分展示、模态框详情交互等通用场景
javascript·react native·react.js·ecmascript·交互·harmonyos
2603_949462102 小时前
Flutter for OpenHarmony社团管理App实战:预算管理实现
android·javascript·flutter
wuhen_n2 小时前
JavaScript内存管理与执行上下文
前端·javascript
Hi_kenyon2 小时前
理解vue中的ref
前端·javascript·vue.js
jin1233223 小时前
基于React Native鸿蒙跨平台地址管理是许多电商、外卖、物流等应用的重要功能模块,实现了地址的添加、编辑、删除和设置默认等功能
javascript·react native·react.js·ecmascript·harmonyos
2501_920931704 小时前
React Native鸿蒙跨平台医疗健康类的血压记录,包括收缩压、舒张压、心率、日期、时间、备注和状态
javascript·react native·react.js·ecmascript·harmonyos
落霞的思绪4 小时前
配置React和React-dom为CDN引入
前端·react.js·前端框架