Ajax 核心知识点全面总结

文章目录

  • Ajax 核心知识点全面总结
    • 一、Ajax 基础概念
      • 1、定义
      • 2、核心特点
    • 二、Ajax 工作原理与核心组件
      • 1、工作流程
      • 2、XMLHttpRequest(XHR)对象
    • 三、Ajax 请求方法与参数
      • 1、常见请求方法
      • 2、请求参数处理
    • 四、Ajax 异步与错误处理
      • 1、异步处理
      • 2、错误处理
    • 五、跨域资源共享(CORS)与解决方案
      • 1、跨域问题
      • 2、解决方案
    • 六、Ajax 与现代替代方案
      • 1、Fetch API(ES6+)
      • 2、Axios(第三方库)
    • 七、Ajax 最佳实践与性能优化
    • 八、Ajax 安全性考虑
    • 九、经典 Ajax 示例(原生 JavaScript)
    • 十、Ajax 封装全局 API

Ajax 核心知识点全面总结

一、Ajax 基础概念

1、定义

Ajax(Asynchronous JavaScript and XML)是一种 无需重新加载整个网页,即可通过 JavaScript 与服务器异步交换数据的技术,用于创建更流畅、响应更快的 Web 应用。

2、核心特点

  1. 异步通信:客户端与服务器通信时不阻塞页面渲染,用户可继续交互。
  2. 数据驱动更新:仅更新页面部分内容,减少带宽消耗。
  3. 多技术融合:结合 JavaScript、XML(或 JSON)、HTML/CSS 等技术。

二、Ajax 工作原理与核心组件

1、工作流程

  1. 客户端通过 JavaScript 发起请求;
  2. 浏览器创建 XMLHttpRequest(XHR) 对象与服务器通信;
  3. 服务器处理请求并返回数据(XML、JSON 等);
  4. JavaScript 接收数据并更新页面 DOM。

2、XMLHttpRequest(XHR)对象

创建方式const xhr = new XMLHttpRequest();
关键方法

  • open(method, url, async):设置请求方法、URL 和异步模式(默认 true)。
  • send(data):发送请求,data 为请求体(GET 请求时可为 null)。
  • abort():取消请求。

关键属性

  • readyState:请求状态(0 - 未初始化,1 - 已调用 open,2 - 已接收响应头,3 - 处理中,4 - 请求完成)。
  • status:HTTP 状态码(如 200 成功,404 未找到)。
  • responseText/responseXML:返回的文本 / XML 数据。

事件监听:

  • onreadystatechange:状态变化时触发,常用于检查 readyState === 4 且 status === 200

三、Ajax 请求方法与参数

1、常见请求方法

方法用途特点
GET获取资源参数附在 URL 后(如 ?key=value),有长度限制,浏览器会缓存。
POST提交数据参数在请求体中,无长度限制,不会缓存。
DELETE删除资源删除指定资源,需服务器支持。
PUT更新资源覆盖式更新,需服务器支持。

2、请求参数处理

  • GET 请求url + '?param1=value1&param2=value2'
  • POST 请求:需设置请求头 Content-Type,如:
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
xhr.send('param1=value1&param2=value2');

或发送 JSON 数据:

xhr.setRequestHeader('Content-Type', 'application/json');
xhr.send(JSON.stringify({ param1: 'value1', param2: 'value2' }));

四、Ajax 异步与错误处理

1、异步处理

  • 传统回调:通过 onreadystatechange 监听请求完成。
  • Promise 封装(现代方式):
function fetchData(url) {return new Promise((resolve, reject) => {const xhr = new XMLHttpRequest();xhr.open('GET', url);xhr.onload = () => resolve(xhr.response);xhr.onerror = () => reject(new Error('请求失败'));xhr.send();});
}

2、错误处理

  • onerror 事件:处理网络错误(如服务器不可达)。
  • 状态码判断:
if (xhr.status >= 200 && xhr.status < 300) {// 成功处理
} else {// 错误处理,如 404、500 等
}

五、跨域资源共享(CORS)与解决方案

1、跨域问题

  • 同源策略限制:浏览器禁止不同域名(协议、域名、端口任一不同)的请求交互。
  • 常见错误:Access-Control-Allow-Origin 缺失。

2、解决方案

  • 服务器配置 CORS:在响应头中添加:
Access-Control-Allow-Origin: * (允许所有域名,生产环境建议指定域名)
Access-Control-Allow-Methods: GET, POST, PUT
  • 代理服务器:前端请求本地代理,由代理转发至目标服务器(如 Node.js 中间件)。
  • JSONP:利用 script 标签跨域特性(仅支持 GET 请求):
function loadScript(url, callback) {const script = document.createElement('script');script.src = url + `?callback=${callback.name}`;window[callback.name] = callback;document.body.appendChild(script);
}

六、Ajax 与现代替代方案

1、Fetch API(ES6+)

  • 优点:更简洁的 Promise 接口,支持流式响应。
  • 示例:
fetch('https://api.example.com/data').then(response => response.json()).then(data => console.log(data)).catch(error => console.error(error));

2、Axios(第三方库)

  • 优点:支持 Promise、请求 / 响应拦截、自动转换 JSON、浏览器与 Node 通用。
axios.get('https://api.example.com/data').then(response => console.log(response.data)).catch(error => console.error(error));

七、Ajax 最佳实践与性能优化

请求优化:

  • 合并多个小请求为大请求,减少 HTTP 连接开销。
  • 使用 GET 请求缓存数据(设置 Cache-Control 头)。

防抖与节流:避免频繁请求(如搜索联想功能)。

超时处理:设置 xhr.timeoutontimeout 事件。
请求取消:使用 AbortController(Fetch API)xhr.abort()

八、Ajax 安全性考虑

  • XSS(跨站脚本攻击):对用户输入数据进行转义,避免直接插入 DOM。
  • CSRF(跨站请求伪造):使用 token 验证请求来源,或设置 SameSite cookie。
  • 敏感数据传输:使用 HTTPS 加密通信。

九、经典 Ajax 示例(原生 JavaScript)

// 发送 GET 请求
const xhr = new XMLHttpRequest();
xhr.open('GET', 'https://api.example.com/users', true);
xhr.onreadystatechange = function() {if (xhr.readyState === 4 && xhr.status === 200) {const users = JSON.parse(xhr.responseText);document.getElementById('users-list').innerHTML = users.map(user => `<li>${user.name}</li>`).join('');}
};
xhr.send();// 发送 POST 请求
const xhrPost = new XMLHttpRequest();
xhrPost.open('POST', 'https://api.example.com/login', true);
xhrPost.setRequestHeader('Content-Type', 'application/json');
xhrPost.onload = function() {if (xhrPost.status === 200) {alert('登录成功');}
};
xhrPost.send(JSON.stringify({ username: 'user', password: 'pass' }));

十、Ajax 封装全局 API

/*** 通用 AJAX 请求工具* 封装了 GET、POST、PUT、DELETE 等常用 HTTP 请求方法*/
const HttpUtils = {/*** 发送 GET 请求* @param {string} url - 请求URL* @param {Object} params - 请求参数* @param {Object} options - 额外配置选项* @returns {Promise<Object>} - 返回Promise对象*/get(url, params = {}, options = {}) {return this.request('GET', url, params, null, options);},/*** 发送 POST 请求* @param {string} url - 请求URL* @param {Object} data - 请求数据* @param {Object} options - 额外配置选项* @returns {Promise<Object>} - 返回Promise对象*/post(url, data = {}, options = {}) {return this.request('POST', url, {}, data, options);},/*** 发送 PUT 请求* @param {string} url - 请求URL* @param {Object} data - 请求数据* @param {Object} options - 额外配置选项* @returns {Promise<Object>} - 返回Promise对象*/put(url, data = {}, options = {}) {return this.request('PUT', url, {}, data, options);},/*** 发送 DELETE 请求* @param {string} url - 请求URL* @param {Object} params - 请求参数* @param {Object} options - 额外配置选项* @returns {Promise<Object>} - 返回Promise对象*/delete(url, params = {}, options = {}) {return this.request('DELETE', url, params, null, options);},/*** 发送 HTTP 请求* @param {string} method - HTTP方法* @param {string} url - 请求URL* @param {Object} params - 请求参数* @param {Object} data - 请求数据* @param {Object} options - 额外配置选项* @returns {Promise<Object>} - 返回Promise对象*/request(method, url, params, data, options) {// 处理URL参数if (params && Object.keys(params).length > 0) {const queryString = Object.entries(params).map(([key, value]) => `${encodeURIComponent(key)}=${encodeURIComponent(value)}`).join('&');url += (url.includes('?') ? '&' : '?') + queryString;}// 创建基础配置const config = {method,headers: {'Content-Type': 'application/json',...options.headers},credentials: options.credentials || 'same-origin',...options};// 添加请求体if (data && (method === 'POST' || method === 'PUT')) {config.body = JSON.stringify(data);}// 返回Promise对象return new Promise((resolve, reject) => {fetch(url, config).then(response => {// 检查HTTP状态码if (!response.ok) {throw new Error(`HTTP error! Status: ${response.status}`);}// 根据Content-Type解析响应const contentType = response.headers.get('Content-Type');if (contentType && contentType.includes('application/json')) {return response.json();} else if (contentType && contentType.includes('text/')) {return response.text();} else {return response.blob();}}).then(result => resolve(result)).catch(error => {console.error('Request failed:', error);reject(error);});});}
};export default HttpUtils;    

以上代码封装了常用的 AJAX 请求方法,支持 GET、POST、PUT、DELETE 四种 HTTP 方法。该工具使用原生的 Fetch API 实现,返回 Promise 对象以便于使用 async/await 语法。主要特点:

  • 支持请求参数自动序列化
  • 自动处理响应内容类型解析(JSON、文本、二进制)
  • 统一的错误处理机制
  • 支持自定义请求头和其他配置选项

在你的项目中,可以将此文件保存为 http-utils.js,然后通过 import 语句在需要的地方引入使用,例如:

import HttpUtils from './http-utils.js';// 使用示例
async function fetchData() {try {// GET 请求示例const result = await HttpUtils.get('/api/users', { page: 1, size: 10 });console.log('GET 请求结果:', result);// POST 请求示例const newUser = { name: 'John', age: 30 };const createResult = await HttpUtils.post('/api/users', newUser);console.log('POST 请求结果:', createResult);} catch (error) {console.error('请求出错:', error);}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/news/909608.shtml
繁体地址,请注明出处:http://hk.pswp.cn/news/909608.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SpinFlowSim:用于癌症组织学信息驱动的扩散MRI微血管映射的血流模拟框架|文献速递-深度学习医疗AI最新文献

Title 题目 SpinFlowSim: A blood flow simulation framework for histology-informeddiffusion MRI microvasculature mapping in cancer SpinFlowSim&#xff1a;用于癌症组织学信息驱动的扩散MRI微血管映射的血流模拟框架 01 文献速递介绍 在扩散磁共振成像&#xff08…

量化面试绿皮书:21. 抛硬币游戏

文中内容仅限技术学习与代码实践参考&#xff0c;市场存在不确定性&#xff0c;技术分析需谨慎验证&#xff0c;不构成任何投资建议。 21. 抛硬币游戏 两个赌徒正在玩一个抛硬币游戏。 赌徒A有(n1)枚均匀硬币&#xff0c;赌徒B有n枚均匀硬币。 Q: 如果两人同时抛掷所有硬币&a…

OpenLayers 框架体系

注&#xff1a;当前使用的是 ol 9.2.4 版本&#xff0c;天地图使用的key请到天地图官网申请&#xff0c;并替换为自己的key OpenLayers框架组织结构庞大&#xff0c;只通过官网API进行查看&#xff0c;对框架结构缺少一个整体、全面的看法。借助树形结构图或思维导图&#xff0…

缓存系统-基本概述

目录 一、系统概述 二、名词解释 三、淘汰策略 1、LRU 2、LFU 3、FIFO 4、TTL 5、Random 四、读写模式 1、Cache Aside&#xff08;旁路缓存&#xff09; 2、Write Through&#xff08;直写&#xff09; 3、Write Back&#xff08;回写&#xff09; 五、问题方案 …

基于GNU Radio Companion搭建的BPSK收发通信实验

目录 一、实验目的和要求 二、实验内容 1.Lab5 仿真设计一个BPSK的数字收发射系统 Lab6 实际使用RTLSDR解调BPSK信号 一、实验目的和要求 1.了解软FM的工作方式和原理,数字通信的码间串扰及星座图 2.掌握并正确使用RTL-SDL硬件和Gnuradio软件 3.正确使用Gnraduo软件,建…

华为OD机试-返回矩阵中非1的元素、个数/数值同化-BFS(JAVA 2025B卷)

import java.util.*;/*** author 308413* version Ver 1.0* date 2025/6/18* description 返回矩阵中非1的元素*/ public class Non1ElementInMatrix {public static void main(String[] args) {Scanner scanner new Scanner(System.in);int N scanner.nextInt();int M scan…

Redis学习笔记——黑马点评 消息队列25-30

前言&#xff1a; 学习收获&#xff1a; Redis消息队列&#xff1a; 消息队列&#xff08;Message Queue&#xff09;&#xff0c;字面意思就是存放消息的队列。最简单的消息队列包括3个角色&#xff1a; 消息队列&#xff1a;存储和管理消息&#xff0c;也被称为消息代理生…

基于Django+Vue3的草莓病害检测系统设计与实现,Web前后端分离,YOLOv8 Web目标检测系统

这里写自定义目录标题 基于DjangoVue3的草莓病害检测系统 基于DjangoVue3的草莓病害检测系统 本项目结合 YOLOv8 与 Django Vue3 &#xff0c;构建了一个通用的 Web 前后端系统&#xff0c;便于用户进行目标检测的操作和展示&#xff0c;实现对图片、视频实时目标检测和摄像头…

【MFC】树控件的使用详解

目录 添加线条链接 添加折叠小按钮 设置树控件的节点和对应的图标 设置默认选中项 设置选中项切换响应函数 涉及接口介绍&#xff1a; 首先我们通过资源视图可以添加一个树形控件&#xff0c;如下&#xff1a; 添加线条链接 在树形控件中&#xff0c;有一个属性“Has…

跨境卖家警报。抽绳背包版权案立案,TRO在即速排查

近日Shenzhenshi Jingyida Trading Co., LTD委托律所Dewitty And Associates, Chtd.对其热销的抽绳设计多功能运动背包发起跨境版权维权&#xff0c;保护范围涵盖产品外观设计。 案件基本情况&#xff1a; 起诉时间&#xff1a;2025-6-12 案件号&#xff1a;25-cv-06509 原…

Android Activity全面解析:从创建到生命周期的完整指南

Activity作为Android四大组件之一&#xff0c;是构建用户界面的核心单元。笔者通过郭霖著的第一行代码入门安卓&#xff0c;内容基本都取自书中&#xff0c;这篇博客作为笔者的笔记同时精简了一些书中内容分享在csdn中 一、Activity的创建与基础配置 1.1 创建Activity的基本步…

深入理解 Python 的 secrets 模块:打造更安全的随机数生成机制

深入理解 Python 的 secrets 模块&#xff1a;打造更安全的随机数生成机制 在构建涉及用户身份认证、权限管理、加密通信等系统时&#xff0c;开发者最不能忽视的一个问题就是“安全性”。安全问题的核心之一在于“随机性”——尤其是密码、验证码、Token、Session、API Key 的…

CHAPTER 19 Concurrency Models in Python

一、A Bit of Jargon 1、关键术语解析 1.1 并发 (Concurrency) 定义: 并发是指同时处理多个待处理任务的能力&#xff0c;这些任务可以依次或并行&#xff08;如果可能&#xff09;进行&#xff0c;最终每个任务都会成功或失败。 理解: 单核 CPU: 即使是单核 CPU 也可以实…

DCM4CHEE Archive Light 开发环境部署(5)-IDEA集成调试配置

系列文章目录 DCM4CHEE Archive light 开发环境部署(1)-前言DCM4CHEE Archive light 开发环境部署(2)-PostgreSQLDCM4CHEE Archive light 开发环境部署(3)-OpenLDAPDCM4CHEE Archive light 开发环境部署(4)-Wildfly(JBoss)DCM4CHEE Archive light 开发环境部署(5)-IDEA集成…

在rust中执行命令行输出中文乱码解决办法

如果你使用标准的依赖库执行命令中包含中文的话&#xff0c; 就会发现中文乱码&#xff0c;如果你的输出中没有中文&#xff0c;就可以正常输出&#xff0c;因为windows的命令行默认使用的是gbk编码。。。。。 #[tauri::command] pub async fn run_command(command: String) -…

判断当前浏览器卡不卡

方法一&#xff1a;使用 requestAnimationFrame 和时间戳计算平均 FPS let frameCount 0; let lastTime performance.now(); let fps 0; let isSlow false; // 是否卡顿的标志function calculateFPS(currentTime) {frameCount;// 每隔大约 1000 毫秒&#xff08;1秒&#…

51c嵌入式~电路~合集2

我自己的原文哦~ https://blog.51cto.com/whaosoft/11748634 一、延长电子元器件的货架寿命 本文探讨了电子元器件的货架寿命问题&#xff0c;重点讨论了氧化、湿度敏感等级&#xff08;MSL&#xff09;与货架寿命之间的关系。文章通过具体例子说明了氧化对电子元器件可…

Eureka 与 Feign(一)

Eureka 与 Feign 知识解析 1. Eureka Spring Cloud Eureka 是服务发现组件&#xff0c;包含&#xff1a; Eureka Server&#xff1a;注册中心&#xff0c;管理服务实例Eureka Client&#xff1a;服务实例&#xff0c;向注册中心注册/获取服务信息 核心功能&#xff1a; 服…

AN动画软件|Animate 2025百度云下载与安装教程指南

如大家所了解的&#xff0c;‌Animate全称Adobe Animate&#xff0c;常常也被简称为AN。它是一款2D动画制作软件‌&#xff0c;其前身为Flash Professional CC&#xff0c;2016年更名为Animate CC&#xff0c;支持Flash SWF文件及HTML5动画创作&#xff0c;广泛应用于网页交互、…

提示词工程中常见协议框架应用实例

一、生成式诊断催化协议(Generative Diagnosis Catalysis, GDC) 技术原理:基于神经符号系统的因果推理引擎,融合贝叶斯网络与强化学习 实施场景: class DiagnosticCatalyst:def __init__(self, domain="医疗诊断"):self.causal_graph