首页 > 其他分享 >Ajax基本原理

Ajax基本原理

时间:2023-11-14 15:14:15浏览次数:35  
标签:XMLHttpRequest 请求 基本原理 AJAX 响应 Ajax 服务器发送 页面

AJAX(Asynchronous JavaScript and XML)是一种基于 JavaScript 和 XML 技术的前端通信方式,可以在不刷新页面的情况下向服务器发送请求,并接收响应数据,实现了前后端的无感通信。本文将介绍 AJAX 的原理及实现方式。

在传统的 Web 应用中,前端页面通过表单提交或者超链接的方式向服务器发送请求,服务器响应后返回一个完整的 HTML 页面,浏览器再重新渲染页面。这个过程需要刷新页面,响应时间较长,用户体验不佳。
而 AJAX 技术可以实现异步请求,即前端向服务器发送请求后,不需要等待服务器的响应,可以继续执行其他的操作,当服务器响应时,再将数据更新到页面上,这样可以大大提高用户体验。

AJAX 的原理是通过 XMLHttpRequest 对象向服务器发送请求,并通过回调函数处理服务器响应的数据。XMLHttpRequest 对象是由浏览器提供的,可以通过 JavaScript 代码进行创建和操作。

二、AJAX 实现方式

1. XMLHttpRequest 对象

XMLHttpRequest 对象是 AJAX 的核心,可以通过它实现前后端的通信。它提供了多种方法和属性,如 open()、send()、onreadystatechange 等。

使用 XMLHttpRequest 对象发送请求需要以下步骤:

① 创建 XMLHttpRequest 对象

var xhr = new XMLHttpRequest();

② 打开请求

xhr.open('GET', url, true);

open() 方法接收三个参数,第一个参数是请求方式,可以是 GET 或 POST;第二个参数是请求的 URL;第三个参数是表示是否异步请求,一般设置为 true。

③ 发送请求

xhr.send(null);

send() 方法可以传入参数,如果是 GET 请求,可以将参数拼接到 URL 后面;如果是 POST 请求,需要将参数作为 send() 的参数传入。

④ 监听响应

xhr.onreadystatechange = function() {
if (xhr.readyState === 4 && xhr.status === 200) {
var response = xhr.responseText;
// 处理响应数据
}
};

onreadystatechange 是 XMLHttpRequest 对象的一个属性,它会在请求状态发生改变时触发回调函数。readyState 表示请求的状态,有以下几个值:

0:未初始化,还没有调用 open() 方法

1:载入,已调用 send() 方法,正在发送请求

2:载入完成,send() 方法执行完成,已接收到全部响应数据

3:交互,正在解析响应数据

4:完成,响应数据解析完成,可以使用

status 表示服务器响应的状态码,200 表示成功,404 表示未找到资源,500 表示服务器内部错误等。

 

2. fetch API
fetch API 是 ES6 新增的一种网络请求方式,可以替代 XMLHttpRequest 对象。它的优点是更加简洁、易用,并且支持 Promise。
使用 fetch API 发送请求需要以下步骤:

① 发送请求

fetch(url, {

method: 'GET',

headers: {

'Content-Type': 'application/json'

}).then(response => {

// 处理响应数据

}).catch(error => {

console.error(error);

});

fetch() 方法接收两个参数,第一个参数是请求的 URL;第二个参数是一个对象,可以设置请求的方式、请求头等信息。
fetch() 方法返回一个 Promise 对象,可以通过 then() 方法处理响应数据,catch() 方法处理异常情况。

3. Axios

Axios 是一种基于 Promise 的 HTTP 客户端,可以在浏览器和 Node.js 中使用。它的优点是可以拦截请求和响应、支持并发请求等。
使用 Axios 发送请求需要以下步骤:

① 安装 Axios

npm install axios
② 发送请求
import axios from 'axios';
axios.get(url).then(response => {
Axios 提供了多种请求方式,如 get()、post()、put()、delete() 等。
Axios 也返回一个 Promise 对象,可以通过 then() 方法处理响应数据,catch() 方法处理异常情况。

AJAX 技术可以应用于多种场景,如:
1. 表单验证
在用户填写表单时,可以通过 AJAX 技术向服务器发送请求,实时验证用户输入的数据是否合法,避免用户提交后再返回错误信息。
2. 搜索框提示
在用户输入关键词时,可以通过 AJAX 技术向服务器发送请求,获取相关的搜索结果,并实时显示在页面上,提高搜索的效率。
3. 无限滚动
在用户滚动页面时,可以通过 AJAX 技术向服务器发送请求,获取更多的数据,并动态更新页面内容,实现无限滚动效果。
4. 购物车
在用户添加商品到购物车时,可以通过 AJAX 技术向服务器发送请求,将商品信息保存到购物车中,并实时更新购物车数量。
总之,AJAX 技术可以实现前后端的无感通信,提高用户体验,应用场景广泛。但是需要注意的是,过度使用 AJAX 技术可能会影响页面性能,需要合理使用。

 

标签:XMLHttpRequest,请求,基本原理,AJAX,响应,Ajax,服务器发送,页面
From: https://www.cnblogs.com/haoxuanchen2014/p/17831609.html

相关文章

  • ajax响应200但一直走error
    做登录功能时发现ajax请求响应正常200也能在预览中国看到响应数据,但是执行的是error$.ajax({type:"post",data:{username:$("#username").val(),password:$("#password").val()},dataType:"json",url:"user/login"......
  • AJAX发送请求到服务器获取信息和状态码到前端浏览器------前端
    AJAX在浏览器当中发送异步请求,请求之间是独立的,谁也不用等谁类似于多线程并发,不会出现页面清空然后展示新的页面的效果实现局部刷新(靠多种技术一起做到的,而不是一个技术叫ajax)它是异步的(类似于多线程)在AJAX的请求以及响应中完全依靠的是XMLHttpRequest对象XMLHttpRequ......
  • 使用 AJAX、PHP 和服务器发送事件从 OpenAI 的 API 流式传输数据
    如何使用服务器发送事件(SSE)将数据从上述API流式传输到使用JavaScript和PHP的浏览器客户端?我已经研究这个问题好几个小时了,但我似乎无法弄清楚出了什么问题。作为参考,我尝试在这里调整解决方案:StreamDATAFromopenaiGPT-3APIusingPHP我的代码的其余部分或多或少与上......
  • 原生JavaScript 与 jQuery 执行Ajax请求
    原生JavaScript和jQuery都可以用来执行Ajax请求,以下是它们的基本实现方式的比较:原生JavaScript实现Ajax请求:varxhr=newXMLHttpRequest();xhr.open("GET","https://api.example.com/data",true);xhr.onreadystatechange=function(){if(xhr.readyState==4&&......
  • SpringBoot整合Ajax
    使用springboot整合ajax实现登录验证及查询信息。添加jar依赖<dependencies><!--<dependency>--><!--<groupId>org.aspectj</groupId>--><!--<artifactId>aspectjweaver</artifactId>-->......
  • Ajax与Flash的优缺点比较
    1.Ajax的优势:1.可搜索性2.开放性3.费用4.易用性5.易于开发。2.Flash的优势:1.多媒体处理2.兼容性3.矢量图形4.客户端资源调度3.Ajax的劣势:1.它可能破坏浏览器的后退功能2.使用动态页面更新使得用户难于将某个特定的状态保存到收藏夹中,不过这些都有相关方法解决。4.Fl......
  • 23.11.10(Ajax和Json的数据传输问题)
    使用Ajax写查询功能,后端数据一直传不到前端,遇到parse解析的卡住原因:传来的json数据格式不正确,后端Java还respond了一个success解决方法:把success去掉<scriptsrc="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script><script>$(d......
  • ASP.NET Ajax exception - Two components with the same id can't be added to the a
    There'sacoupleofexceptionstolookoutforwhenyoustartdevelopingcustomASP.NETAjaxclientcontrols. Theyare:MicrosoftJScriptruntimeerror:Sys.InvalidOperationException:Twocomponentswiththesameid'ctl00_MainContentPlaceHold......
  • 10 Mar 10 Auto Complete Ajax Scripts
    In2005whenGoogleimplementedGoogleSuggest,Ajaxtookoff.EverywebdeveloperwastryingtoduplicatewhatGoogleaccomplished.Itsnow2008andtherearetonsofwaystoaccomplishGoogleSuggest.Belowisalistof10AutoCompleteScriptswithvar......
  • NLP机器翻译全景:从基本原理到技术实战全解析
    机器翻译是使计算机能够将一种语言转化为另一种语言的技术领域。本文从简介、基于规则、统计和神经网络的方法入手,深入解析了各种机器翻译策略。同时,详细探讨了评估机器翻译性能的多种标准和工具,包括BLEU、METEOR等,以确保翻译的准确性和质量。关注TechLead,分享AI全维度知识。......