一.概述

概念:AJAX(Asynchronous JavaScript And XML):异步的 JavaScript 和 XML 作用:

与服务器进行数据交换:通过AJAX可以给服务器发送请求,并获取服务器响应的数据 使用了AJAX和服务器进行通信,就可以使用 HTML+AJAX来替换JSP页面,可以说是终结了JSP的存在,促使了前后端分离开发

2. 实现异步交互:可以在不重新加载整个页面的情况下,与服务器交换数据并更新部分网页的技术,如:搜索时的联想、检查用户名是否可用校验,等等

补充说明:异步&同步通信

二.使用

(1) GET请求

(1.1) 流程

创建 XMLHttpRequest 对象:用于和服务器交换数据

let xhr = new XMLHttpRequest();

向服务器发送请求

xhr.open("GET","url");

xhr.send();

获取服务器响应数据

// 监听请求

xhr.onreadystatechange = function () {

// 表示请求成功并且获取到响应数据

if (xhr.readyState == 4 && xhr.status == 200){

alert(xhr.responseText);

// 拿到数据进行一系列操作....

}

}

相关属性说明:

属性描述onreadystatechange定义当 readyState 属性发生变化时被调用的函数readyState保存 XMLHttpRequest 的状态。0:请求未初始化 1:服务器连接已建立 2:请求已收到 3:正在处理请求 4:请求已完成且响应已就绪responseText以字符串返回响应数据responseXML以 XML 数据返回响应数据status返回请求的状态号200: "OK"403: "Forbidden"404: "Not Found"如需完整列表请访问 Http 消息参考手册statusText返回状态文本(比如 “OK” 或 “Not Found”)

(1.2) 完整代码示例

如果需要,可以通过?在url后面拼接请求参数

// 1.创建 XMLHttpRequest 对象:用于和服务器交换数据

let xhr = new XMLHttpRequest();

// 2.向服务器发送请求

xhr.open("GET", "http://localhost/newsWork_war_exploded/Search?searchText=" + searchText.value);

xhr.send();

// 3.获取服务器响应数据

xhr.onreadystatechange = function () {

// 表示请求成功并且获取到响应数据

if (xhr.readyState == 4 && xhr.status == 200){

alert(xhr.responseText);

// 拿到数据可以进行一系列操作....

}

}

简单使用示例:

(2) POST请求

post请求发送方式与Get请求类似

(2.1) 流程

创建 XMLHttpRequest 对象:用于和服务器交换数据

let xhr = new XMLHttpRequest();

向服务器发送请求

// 方式一:简单请求

xhr.open("POST","url");

xhr.send();

// 方式二:

// 如需像 HTML表单那样发送数据,需通过 `setRequestHeader()` 添加一个 HTTP 头部。

// 请在 `send()` 方法中规定您需要发送的数据

// 2.1 发起请求

xhr.open("POST", 'http://localhost/newsWork_war_exploded/login');

// 2.2 设置HTTP头部

xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded");

// 2.3 规定需要发送的数据

xhr.send(`username=${username.value}&userPassword=${userPassword.value}`);

获取服务器响应数据

xhr.onreadystatechange = function () {

// 表示请求成功并且获取到响应数据

if (xhr.readyState == 4 && xhr.status == 200){

alert(xhr.responseText);

// 拿到数据可以进行一系列操作....

}

}

相关属性说明:

属性描述onreadystatechange定义当 readyState 属性发生变化时被调用的函数readyState保存 XMLHttpRequest 的状态。0:请求未初始化 1:服务器连接已建立 2:请求已收到 3:正在处理请求 4:请求已完成且响应已就绪responseText以字符串返回响应数据responseXML以 XML 数据返回响应数据status返回请求的状态号200: "OK"403: "Forbidden"404: "Not Found"如需完整列表请访问 Http 消息参考手册statusText返回状态文本(比如 “OK” 或 “Not Found”)

(2.2) 完整代码示例

post与get不同之处在于需要自己设置HTTP头部并在send中规定传递参数

// 1.创建 XMLHttpRequest 对象:用于和服务器交换数据

let xhr = new XMLHttpRequest();

// 2.向服务器发送请求

xhr.open("POST", 'http://localhost/newsWork_war_exploded/login');

// 2.1设置HTTP头部

xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded");

// 2.2规定需要发送的数据

xhr.send(`username=${username.value}&userPassword=${userPassword.value}`);

// 3.获取服务器响应数据

xhr.onreadystatechange = function () {

// 表示请求成功并且获取到响应数据

if (xhr.readyState == 4 && xhr.status == 200){

alert(xhr.responseText);

// 3.1 拿到数据可以进行一系列操作....

}

}

简单使用示例:

三.补充

(1) 发起同步请求

open方法的完整格式如下:

open(method, url, async)

method:请求的类型:GET 还是 POST url:服务器(文件)位置 async:true(异步)或 false(同步) |

由于其不写默认是true异步请求,所以我们可以不用设置。当如果我们需要使用同步请求时,我们需要手动将第三个参数设置为false

xhr.open("method", 'url', false);

xhr.send();

// 不用再监听状态(xhr.onready....)

// 可直接使用结果

alert(xhr.responseText);

不推荐使用,常用于一些快速测试。需要注意的是,当我们发起同步请求时,此操作可能会导致应用程序挂起或停止(无法再执行其他操作)。而通过异步发送,JavaScript 不必等待服务器响应,可继续执行其他操作

(2) Json格式

在post请求中我们也可以传递和接收Json格式的数据:

可以自己将对象转为Json传递

const requestData = JSON.stringify(formDate)

xhr.send(paramDate)

接收并解析Json格式数据

// 方式一:手动解析

const responseData = JSON.parse(xhr.responseText)

// 方式二: 设置自动解析

xhr.responseType='json'

参考文章

评论可见,请评论后查看内容,谢谢!!!
 您阅读本篇文章共花了: