AJAX 请求理解

AJAX 请求理解

一、什么是 AJAX?

AJAX(Asynchronous JavaScript and XML)

中文:异步 JavaScript 和 XML

本质

不刷新页面的情况下,与服务器进行数据交互

作用

  • 局部更新页面(提升用户体验)
  • 提高性能(减少整页刷新)
  • 实现前后端分离

二、AJAX 的核心特点

特点 说明
异步 请求不阻塞页面运行
局部刷新 只更新部分 DOM
前后端通信 使用 HTTP 请求
数据格式灵活 JSON(主流)、XML、Text

三、AJAX 工作原理

流程:

  1. 用户触发事件(点击按钮等)
  2. JavaScript 创建请求
  3. 发送 HTTP 请求到服务器
  4. 服务器返回数据
  5. JS 接收数据并更新页面

简化理解:

复制代码
浏览器(JS)  ←→  服务器(API)

四、AJAX 实现方式(重点)

原生 XMLHttpRequest(了解)

js 复制代码
var xhr = new XMLHttpRequest();

xhr.open("GET", "/api/user", true);

xhr.onreadystatechange = function () {
    if (xhr.readyState === 4 && xhr.status === 200) {
        console.log(xhr.responseText);
    }
};

xhr.send();
readyState 状态
含义
0 未初始化
1 已建立连接
2 已发送请求
3 接收中
4 完成

Fetch(主流 )

js 复制代码
fetch("/api/user")
  .then(res => res.json())
  .then(data => {
      console.log(data);
  })
  .catch(err => {
      console.error(err);
  });
优点
  • 语法简洁
  • 基于 Promise
  • 更现代

async / await(推荐 )

js 复制代码
async function getUser() {
    try {
        const res = await fetch("/api/user");
        const data = await res.json();
        console.log(data);
    } catch (err) {
        console.error(err);
    }
}

最接近同步写法,面试加分项


五、常见请求方式(HTTP)

方法 用途
GET 获取数据
POST 提交数据
PUT 更新数据
DELETE 删除数据

六、发送 POST 请求示例

js 复制代码
fetch("/api/login", {
    method: "POST",
    headers: {
        "Content-Type": "application/json"
    },
    body: JSON.stringify({
        username: "admin",
        password: "123456"
    })
})
.then(res => res.json())
.then(data => console.log(data));

七、AJAX 常见数据格式

JSON(最重要)

js 复制代码
{
  "username": "admin",
  "age": 20
}

JS 转换:

复制代码
JSON.parse()   // 字符串 → 对象
JSON.stringify() // 对象 → 字符串

八、AJAX 优缺点

优点

  • 用户体验好(不卡顿)
  • 减少服务器压力
  • 支持动态页面

缺点

  • SEO 不友好
  • 依赖 JS
  • 存在跨域问题

九、跨域问题(重点 )

什么是跨域

浏览器限制不同源之间的请求

不同源指:
  • 协议不同(http / https)
  • 域名不同
  • 端口不同

解决方案

CORS(最常用 )

服务器返回:

复制代码
Access-Control-Allow-Origin: *

JSONP(已过时)

只支持 GET


代理服务器(开发常用)

十、AJAX 在项目中的应用

结合你现在做的用户管理系统,AJAX可以用在:

示例

1. 登录
js 复制代码
fetch("/api/login", { method: "POST" })
2. 获取用户列表
js 复制代码
fetch("/api/users")
3. 删除用户
js 复制代码
fetch("/api/user/1", {
    method: "DELETE"
})
4. 修改用户信息
js 复制代码
fetch("/api/user/1", {
    method: "PUT"
})

十一、AJAX 面试常问问题

AJAX 和 Fetch 区别

  • AJAX 是概念
  • Fetch 是实现方式

AJAX 是同步还是异步?

默认异步(可以同步但不推荐)


为什么推荐 async/await?

  • 可读性强
  • 避免回调地狱

AJAX 和 axios 区别?

  • axios 是库(封装更强)
  • fetch 是原生 API

十二、总结(核心记忆)

一句话理解:

AJAX = 用 JS 在后台偷偷请求数据,不刷新页面更新内容

相关推荐
小白学大数据1 小时前
Python 自动化爬取网易云音乐歌手歌词实战教程
爬虫·python·okhttp·自动化
前端摸鱼匠1 小时前
Vue 3 的v-bind合并行为:讲解v-bind与普通属性合并的规则
前端·javascript·vue.js·前端框架·ecmascript
REDcker2 小时前
浏览器端Web程序性能分析与优化实战 DevTools指标与工程清单
开发语言·前端·javascript·vue·ecmascript·php·js
donecoding3 小时前
一个 sudo 引发的血案:npm 全局包权限错乱彻底修复
前端·node.js·前端工程化
风骏时光牛马3 小时前
Raku正则匹配与数据批量处理实操案例
前端
nbwenren3 小时前
2026实测:Gemini 3 镜像站视觉能力实践——拍照原型图,一键生成 HTML+CSS 代码
前端·css·html
Lee川3 小时前
Prisma 实战指南:像搭积木一样设计古诗词数据库
前端·数据库·后端
jinanwuhuaguo4 小时前
(第二十九篇)OpenClaw 实时与具身的跃迁——从异步孤岛到数字世界的“原住民”
前端·网络·人工智能·重构·openclaw
广州华水科技4 小时前
深度测评2026年单北斗GNSS位移监测系统推荐,与高口碑变形监测设备一同引领行业新风尚
前端