当前位置 : 祺云SEO > 程序编程>

如何用原生JS实现Ajax?原生js实现ajax请求的方法

时间:2026-06-25 来源:祺云SEO
【半小时带你搞定Ajax】手把手教你如何使用Ajax发送请求,实现前后端交互,调用接口等-JavaScript-前端开发-调接口-ajax教程
3岁爱上编程
15.1万2590503原视频地址

为什么现在还要学原生Ajax实现

尽管jQuery的$.ajax方法曾统治前端多年,但现代浏览器已经原生支持更强大的API,业内专家指出,直接操作原生API能带来更细粒度的控制权和更小的运行时开销。

性能与体积的权衡

在移动端网络环境依然复杂的今天,每增加一个第三方库都意味着额外的下载时间和解析成本,原生Ajax实现无需引入任何外部依赖,代码体积几乎可以忽略不计,对于只需要简单获取JSON数据或提交表单的场景,使用原生API是最高效的选择。

具体场景对比

  • 传统页面跳转:用户点击按钮,整个页面重新加载,白屏等待时间长,用户体验割裂。
  • 原生Ajax交互:用户点击按钮,后台静默请求数据,仅更新局部DOM,页面保持流畅,感知延迟极低。

调试与排错的优势

当使用框架封装的请求出现错误时,往往需要层层深入源码才能定位问题,而使用原生XMLHttpRequest或Fetch,你可以直接通过浏览器开发者工具的Network面板观察请求头、响应体以及状态码变化,这种透明度对于解决“为什么数据没更新”或“为什么请求被拦截”等疑难杂症至关重要。

XMLHttpRequest原语详解

XMLHttpRequest(简称XHR)是Ajax技术的鼻祖,尽管它有着“XML”这个名字,但它完全可以传输JSON、文本甚至二进制数据,它是所有现代异步通信的基础。

创建与初始化

你需要实例化XHR对象,这一步在所有主流浏览器中都是通用的。

varxhr=newXMLHttpRequest();

调用open方法初始化请求,这个方法接收三个主要参数:请求方法(如GET、POST)、请求URL以及是否异步(默认为true)。

xhr.open('GET','/api/data',true);

设置请求头与发送

如果需要发送POST请求,必须手动设置Content-Type头部,否则服务器可能无法正确解析Body中的数据。

xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');xhr.send('name=test&value=https://idctop.com/article/123');

监听状态变化

XHR的核心机制是基于事件的,你需要监听onreadystatechange事件,并通过readyState属性判断当前请求阶段。

  • 0:未初始化
  • 1:服务器连接已建立
  • 2:请求已接收
  • 3:请求处理中
  • 4:请求已完成,且响应已就绪

只有当readyState为4且status为200时,才能安全地读取xhr.responseText

FetchAPI的现代实践

FetchAPI是W3C推出的新一代HTTP数据获取接口,它基于Promise,语法更简洁,且天然支持异步/await模式,在2026年的项目选型中,Fetch已成为大多数新项目的首选方案。

基本用法与Promise链

Fetch返回一个Promise对象,这使得错误处理更加直观。

fetch('/api/data').then(response=>{if(!response.ok){thrownewError('网络响应错误');}returnresponse.json();}).then(data=https://idctop.com/article/>console.log(data))>

Async/Await的优雅写法

对于习惯顺序思维的开发者,async/await让异步代码看起来像同步代码,极大提升了可读性。

asyncfunctionloadData(){try{constresponse=awaitfetch('/api/data');if(!response.ok)thrownewError('HTTPerror!');constdata=https://idctop.com/article/awaitresponse.json();>

常见陷阱与最佳实践

原生Ajax实现虽然强大,但开发者容易陷入一些常见的误区,了解这些陷阱,能帮你写出更健壮的代码。

跨域问题(CORS)

浏览器出于安全考虑,默认禁止跨域请求,当你的前端域名与后端API域名不一致时,会触发CORS策略,解决这一问题通常需要在后端服务器配置Access-Control-Allow-Origin头,前端无法通过JS代码绕过此限制,这是浏览器的同源策略决定的。

取消请求

在SPA应用中,用户可能快速切换页面,导致之前的请求尚未返回,如果此时更新DOM,可能会引发状态混乱,FetchAPI提供了AbortController,可以方便地取消未完成的请求。

constcontroller=newAbortController();constsignal=controller.signal;fetch('/api/slow-data',{signal}).then(...).catch(err=>{if(err.name==='AbortError'){console.log('请求已取消');}});//在组件卸载或用户离开时调用controller.abort();

JSON解析的安全性

虽然response.json()很方便,但在处理不受信任的源时,需注意潜在的注入风险,确保后端返回的数据结构符合预期,并在前端进行必要的校验。

原生Ajax实现与框架封装对比

为了更清晰地理解差异,我们将原生实现与主流框架的请求封装进行对比。

特性 原生XMLHttpRequest 原生FetchAPI Vue/Axios封装 语法风格 回调函数,较繁琐 Promise/Async-Await,现代 基于Promise,链式调用 默认行为 需手动设置Header 默认不发送Cookie 可配置自动携带Cookie

错误处理依赖status码网络错误才reject,HTTP错误需手动判断统一拦截器处理

取消请求需调用abort()需AbortController内置CancelToken或AbortController适用场景兼容极老浏览器现代浏览器,轻量级项目中大型项目,统一规范

据工信部数据,现代浏览器对Fetch的支持率已接近100%,但在涉及老旧系统维护时,XHR依然有其用武之地,多数情况下,新项目应优先选择Fetch,以获得更好的开发体验和性能。

原生Ajax实现常见问题解答

原生Ajax实现中如何处理POST请求的参数序列化?

在XMLHttpRequest中,如果发送的是表单数据,需手动调用URLSearchParams或拼接字符串,并设置Content-Typeapplication/x-www-form-urlencoded,如果使用Fetch,可以直接在body中传递字符串或FormData对象,Fetch会自动处理部分序列化逻辑,但需注意对象类型需转为JSON字符串并设置Content-Type:application/json

FetchAPI与XMLHttpRequest在错误处理上有何本质区别?

XMLHttpRequest在HTTP状态码为4xx或5xx时,不会触发onerror事件,而是正常完成请求,开发者需检查status属性,而FetchAPI只有在网络故障(如断网、DNS解析失败)时才会rejectPromise,对于404或500状态码,Promise依然会resolve,开发者必须在.then中手动检查response.ok或response.status来抛出错误。

在2026年是否还需要兼容IE11的Ajax实现?

随着微软正式停止对IE11的支持,绝大多数企业级项目已不再需要兼容IE11,如果项目确实需要兼容IE11,必须使用XMLHttpRequest,因为Fetch和Promise在IE11中不支持,通常需要引入polyfill库来模拟Promise行为,或者使用Babel等工具将ES6+代码转译为ES5。