当前位置: 首页 > news >正文

探索 AJAX 技术:实现动态数据交互的前端利器

简介:
AJAX(Asynchronous JavaScript and XML)技术在 Web 前端开发中扮演着重要的角色,它通过异步通信和动态内容更新,为用户带来更好的交互体验。本篇笔记将详细探索 AJAX 技术,并通过生动的代码演示来展示其在实现动态数据交互方面的优势。

一、AJAX 技术基础

1. 异步通信

异步通信是一种在 Web 开发中的数据交换方式,它允许在后台与服务器进行通信而不阻塞用户界面的操作。在异步通信中,浏览器可以并行处理其他任务,不需要等待服务器的响应就能够继续执行其他的操作。这使得用户可以获得更好的交互体验,而不必等待整个页面重新加载。

与传统的同步请求相比,异步通信的主要区别在于程序执行的流程

  • 同步请求:在发出一个请求后,程序会一直等待服务器返回响应,期间无法执行其他任务。只有当服务器返回响应后,程序才能继续向下执行
  • 异步通信:在发出一个请求后,程序不会等待服务器响应,而是继续向下执行其他任务。当服务器返回响应时,通过事件监听器或回调函数来处理返回的数据。

2. XMLHttpRequest 对象

XMLHttpRequest 是 AJAX 技术的核心组件之一,作为一个 JavaScript 对象,它提供了在浏览器和服务器之间进行异步通信的功能。

XMLHttpRequest 主要用于发送 HTTP 请求到服务器并获取响应,以下是它的一些常用属性和方法:

  • 属性:

    • readyState:表示 XMLHttpRequest 对象的状态,有不同的数值代表不同的状态。

      readyState === 0 : 表示未初始化完成,也就是 open 方法还没有执行
      readyState === 1 : 表示配置信息已经完成,也就是执行完 open 之后
      readyState === 2 : 表示 send 方法已经执行完成
      readyState === 3 : 表示正在解析响应内容
      readyState === 4 :表示响应内容已经解析完毕,可以在客户端使用了

    • status:表示服务器响应的状态码,常用的有 200 表示请求成功。

    • responseTextresponseXML:保存服务器返回的数据,可以通过这两个属性获取响应的文本内容或 XML 内容。

  • 方法:

    • open(method, url, async):创建一个新的 HTTP 请求,指定请求类型(GET 或 POST)、URL 和是否为异步请求。
    • send(data):发送 HTTP 请求,可选地附带请求数据。

XMLHttpRequest 还有其他的一些属性和方法,可以用于设置请求头、监视请求进度等。它的使用方式相对简单,并且在现代浏览器中得到了广泛支持,这里就不过多介绍了。

通过使用 XMLHttpRequest 对象,我们可以实现在浏览器中向服务器发送异步请求,并适时处理服务器响应的数据,从而实现动态数据交互的功能。

二、AJAX 的工作原理

1. 发送异步请求

  • 创建新的XMLHttpRequest对象。
  • 使用open()方法设置请求类型、URL和是否异步。
  • 通过send()方法发送请求。

2. 处理服务器响应

  • 使用onreadystatechange事件监听器,了解请求状态变化。
  • 检查readyState属性的值,判断请求状态。
  • readyState值为4或 status值为200(即请求已完成)时,通过responseTextresponseXML属性获取服务器响应数据

3.具体步骤

  1. 创建新的 XMLHttpRequest 对象:
const xhr = new XMLHttpRequest();
  1. 使用open()方法设置请求类型、URL 和是否异步:
xhr.open('GET', 'example.com/api/data', true);

我们使用 GET 方法向 URL “example.com/api/data” 发送异步请求。第三个参数为true表示以异步方式发送请求。

  1. 通过send()方法发送请求:
xhr.send();

通过调用send()方法,我们向服务器发送异步请求。此时,可以选择附带请求数据作为参数传递给 send() 方法,例如 POST 请求中需要传递表单数据。

  1. 使用 onreadystatechange 事件监听器了解请求状态变化:
xhr.onreadystatechange = function() {if (xhr.readyState === 4) {// 处理服务器响应}
};

XMLHttpRequest 对象的 onreadystatechange 属性指定一个事件监听器函数,该函数会在 readyState 发生变化时被调用。

  1. 检查readyStatestatus属性的值,判断请求状态:
if (xhr.readyState === 4 && xhr.status === 200) {// 处理服务器响应
}
  1. readyState 值为 4 时,通过responseTextresponseXML 属性获取服务器响应数据:
if (xhr.readyState === 4 && xhr.status === 200) {let responseData = xhr.responseText;// 处理响应数据} else {// 请求失败时的处理逻辑
}

整体代码示例:

const xhr = new XMLHttpRequest();
xhr.open('GET', 'example.com/api/data', true);
xhr.onreadystatechange = function() {if(xhr.readyState === 4 && xhr.status === 200) {let responseData = xhr.responseText;// 处理响应数据} else {// 请求失败时的处理逻辑}
};
xhr.send();

三、动态数据交互示例

在这个示例中,我们将使用AJAX从服务器异步获取数据,并用JavaScript动态更新页面显示。

  1. HTML 结构:创建一个简单的HTML结构,包含用于显示数据的元素,如<ul>标签。

  2. CSS 样式:美化页面,为数据展示区域添加样式。

  3. JavaScript 代码:

    • 创建并配置XMLHttpRequest对象。
    • 定义onreadystatechange事件监听器,处理服务器响应。
    • 发送异步请求,获取服务器数据。
    • 当请求完成时,解析服务器响应数据。
    • 使用JavaScript操作DOM,动态更新页面显示数据。
  4. 服务器端:模拟服务器返回数据,可以使用本地JSON文件或通过后端API提供数据。

index.html

<!DOCTYPE html>
<html>
<head><meta charset="UTF-8"><title>AJAX 数据交互示例</title><link rel="stylesheet" type="text/css" href="styles.css">
</head>
<body><h1>动态数据交互示例</h1><ul id="dataList"><!-- 这里将通过JavaScript动态生成数据列表 --></ul><script>const xmlhttp = new XMLHttpRequest();xmlhttp.onreadystatechange = function() {if (this.readyState === 4 && this.status === 200) {let data = JSON.parse(this.responseText);const dataList = document.getElementById("dataList");for (let i = 0; i < data.length; i++) {const listItem = document.createElement("li");listItem.innerText = data[i].name + " - " + data[i].age;dataList.appendChild(listItem);}}};xmlhttp.open("GET", "data.json", true);xmlhttp.send();</script>
</body>
</html>

data.json

[{"name": "John","age": 25},{"name": "Mike","age": 30},{"name": "Emily","age": 28}
]

styles.css

body {font-family: Arial, sans-serif;
}h1 {text-align: center;color: #333;
}ul {list-style-type: none;padding: 0;margin: 15px 0;
}li {background-color: #f5f5f5;padding: 10px;border: 1px solid #ccc;margin-bottom: 5px;
}

四、封装Ajax

原理: 使用 Promise 对象来处理异步请求,并将 AJAX 封装在 ajax 函数中。

函数接受一个参数 options,是一个包含请求相关信息的对象参数。可以设置的选项包括:

  • method:请求方法,默认为 'GET'
  • url:请求的 URL
  • headers:请求头部配置对象
  • params:请求的查询参数(GET 请求)或请求体数据(POST 请求)

ajax 函数返回一个新的 Promise 对象,处理异步请求,成功时调用 resolve,失败时调用 reject

function ajax(options) {return new Promise(function(resolve, reject) {const xhr = new XMLHttpRequest();xhr.open(options.method || 'GET', options.url);xhr.onload = () => {if (xhr.status >= 200 && xhr.status < 300) {resolve(xhr.responseText);} else {reject(new Error(xhr.statusText));}};xhr.onerror = () => {reject(new Error('Network Error'));};if (options.headers) {Object.keys(options.headers).forEach(function(key) {xhr.setRequestHeader(key, options.headers[key]);});}let params = options.params;if (params && typeof params === 'object') {params = Object.keys(params).map(function(key) {return encodeURIComponent(key) + '=' + encodeURIComponent(params[key]);}).join('&');}xhr.send(params);});
}

使用示例:通过调用 ajax 函数发送了一个 GET 请求,指定了 URL 和查询参数 key: value。然后使用 Promise 的 then 方法处理响应数据,和 catch 方法处理错误信息

ajax({method: 'GET',url: 'https://api.example.com/data',params: { key: 'value' }
}).then(function(response) {// 处理成功的响应console.log(response);
}).catch(function(error) {// 处理错误console.error(error);
});

五、Ajax 框架和工具

1.Axios

一个基于 Promise 的 HTTP 客户端库,用于浏览器和 Node.js 上进行异步请求和处理响应。

  • 使用 Axios 进行 GET 请求:

    axios.get('https://api.example.com/data').then(function (response) {console.log(response.data);}).catch(function (error) {console.error(error);});
    
  • 使用 Axios 进行 POST 请求:

    axios.post('https://api.example.com/data', { name: 'John', age: 25 }).then(function (response) {console.log(response.data);}).catch(function (error) {console.error(error);});
    

2.Fetch API

新一代的原生 JavaScript API,用于进行网络请求,替代了传统的 XMLHttpRequest 对象。
下面是Axios和Fetch API的一些应用举例:

  • 使用 Fetch API 进行 GET 请求:

    fetch('https://api.example.com/data').then(function (response) {return response.json();}).then(function (data) {console.log(data);}).catch(function (error) {console.error(error);});
    
  • 使用 Fetch API 进行 POST 请求:

    fetch('https://api.example.com/data', {method: 'POST',headers: {'Content-Type': 'application/json'},body: JSON.stringify({ name: 'John', age: 25 })
    }).then(function (response) {return response.json();}).then(function (data) {console.log(data);}).catch(function (error) {console.error(error);});
    

注意: 在使用 Fetch API 时,需要通过 .json() 方法将响应数据解析为 JSON 格式。同时,两种工具都支持使用 .then() 方法链式调用,以及使用 .catch() 方法捕获请求错误。

相关文章:

探索 AJAX 技术:实现动态数据交互的前端利器

简介&#xff1a; AJAX&#xff08;Asynchronous JavaScript and XML&#xff09;技术在 Web 前端开发中扮演着重要的角色&#xff0c;它通过异步通信和动态内容更新&#xff0c;为用户带来更好的交互体验。本篇笔记将详细探索 AJAX 技术&#xff0c;并通过生动的代码演示来展示…...

深度学习Redis(3):主从复制

前言 在前面的两篇文章中&#xff0c;分别介绍Redis内存模型和Redis持久化 在Redis的持久化中曾提到&#xff0c;Redis高可用的方案包括持久化、主从复制&#xff08;及读写分离&#xff09;、哨兵和集群。其中持久化侧重解决的是Redis数据的单机备份问题&#xff08;从内存到…...

php笔记1

php环境 PHP作为一种服务器端脚本语言&#xff0c;可以在各种操作系统上运行。搭建PHP网站的环境&#xff0c;你需要以下几个要素&#xff1a; Web服务器&#xff1a;常见的选择有Apache、Nginx和IIS。你需要安装和配置其中一个服务器软件。PHP解释器&#xff1a;PHP是一种解…...

2023 ChinaJoy 圆满闭幕,FairGuard游戏加固亮相 BTOB 展区

提振行业 产业复苏 2023年7月28日至7月31日&#xff0c;第二十届中国国际数码互动娱乐展览会( ChinaJoy)于上海新国际博览中心圆满举办。本届ChinaJoy作为疫情结束后的第一个国际性数字娱乐领域的重要产业盛会&#xff0c;对于提振行业信心、加快产业复苏、增进国际间的交流与…...

数据规约策略

有很多概念平时一直在说&#xff0c;但是具体的应用场景却一直不明确&#xff0c;这会导致我们在实际应用过程中对应该使用的方法不够明确&#xff0c;在此对常用的几种数据挖掘方法使用场景进行分类和整合。 数据降维 为什么要降维 数据稀疏&#xff0c;维度高高维数据采用…...

服务器带宽独享跟共享有什么区别103.36.166.x

独享带宽 独享带宽针对对带宽有较高的要求&#xff0c;其业务的内容和性质决定只有使用独立的带宽资源才能满足品质的需求&#xff0c;而这种只给单独客户使用的带宽资源称为独享带宽. 使用独享带宽&#xff0c;整个带宽资源归属于一个客户 独享带宽的优点是可自由使用带宽量…...

【cluster_block_exception】写操作elasticsearch索引报错

【cluster_block_exception】操作elasticsearch索引b报错 背景导致原因&#xff1a;解决方法&#xff1a; 背景 今天线上elk的数据太多&#xff0c;服务器的空间不足了。所以打算删除一些没用用的数据。我是用下面的request&#xff1a; POST /{index_name}/_delete_by_query…...

chaitin-Nginx+Docker

Nginx实战 任务一 1、源码包安装NGINX A&#xff0c;搭建Web Server&#xff0c;任意HTML页面&#xff0c;其8080端口提供Web访问服务&#xff0c;截图成功访问http(s)&#x1f615;/[Server1]:8080并且回显Web页面 官网地址&#xff1a;http://nginx.org/en/download.html 步骤…...

具体面试题

具体面试题 Java 基础 JDK 和 JRE 有什么区别&#xff1f; 和 equals 的区别是什么&#xff1f; 两个对象的 hashCode() 相同&#xff0c;则 equals() 也一定为 true&#xff0c;对吗&#xff1f; final 在 java 中有什么作用&#xff1f; java 中的 Math.round(-1.5) 等…...

Logback ThresholdFilter LevelFilter

当我们需要对日志的打印要做一些范围的控制的时候&#xff0c;通常都是通过为各个Appender设置不同的Filter配置来实现。在Logback中自带了两个过滤器实现&#xff1a; ch.qos.logback.classic.filter.LevelFilter和 ch.qos.logback.classic.filter.ThresholdFilter&#xff0c…...

python+django+mysql项目实践二(前端及数据库)

python项目实践 环境说明&#xff1a; Pycharm 开发环境 Django 前端 MySQL 数据库 Navicat 数据库管理 前端模板 添加模板 在templates下创建 views文件中添加 创建数据库 连接数据库 在setting文件中进行配置 创建表...

Kubernetes高可用集群二进制部署(五)kubelet、kube-proxy、Calico、CoreDNS

Kubernetes概述 使用kubeadm快速部署一个k8s集群 Kubernetes高可用集群二进制部署&#xff08;一&#xff09;主机准备和负载均衡器安装 Kubernetes高可用集群二进制部署&#xff08;二&#xff09;ETCD集群部署 Kubernetes高可用集群二进制部署&#xff08;三&#xff09;部署…...

拦截器对接口细粒度权限校验

文章目录 一、逻辑分析二、校验规则1.规则类型2.规则划分3.规则配置信息4.规则案例说明5.规则加载 三、拦截器定义1.自定义拦截器2.注册拦截器 四、获取请求参数1.获取get提交方式参数2.获取post提交方式参数&#xff08;1&#xff09;定义RequestWrapper类&#xff08;2&#…...

计算机科技历史纵横:8月6日的十大里程碑

计算机科技历史纵横&#xff1a;8月6日的十大里程碑 目录 引言1951年&#xff1a;EDSAC电脑完成第一个实际计算任务1964年&#xff1a;IBM发布System/360系列1973年&#xff1a;Xerox PARC开发出第一台个人电脑Xerox Alto1976年&#xff1a;Apple发布Apple I电脑1981年&#…...

知识图谱实战应用23-【知识图谱的高级用法】Neo4j图算法的Cypher查询语句实例

大家好,我是微学AI,今天给大家介绍一下知识图谱实战应用23-【知识图谱的高级用法】Neo4j图算法的Cypher查询语句实例,Neo4j图算法是一套在Neo4j图数据库上运行的算法集合。这些算法专门针对图数据结构进行设计,用于分析、查询和处理图数据。图算法可以帮助我们发现图中的模…...

C++ 头文件函数大全

<cstdio>头文件&#xff1a; scanf("%d",&a); cin>>a; scanf("%d%d",&a,&b); cin>>a>>b; for(i1;i<n;i) scanf("&d,&alil); cin>>a[i]; printf("%d",a); cout&l…...

智慧物流园区整体架构方案【46页PPT】

导读&#xff1a;原文《智慧物流园区整体架构方案【46页PPT】》&#xff08;获取来源见文尾&#xff09;&#xff0c;本文精选其中精华及架构部分&#xff0c;逻辑清晰、内容完整&#xff0c;为快速形成售前方案提供参考。 完整版领取方式 完整版领取方式&#xff1a; 如需获取…...

llama2模型下载

介绍 LLaMA 2-CHAT与OpenAI ChatGPT效果一样好。LLaMA 2与LLaMA 1架构相同,LLaMA 2训练数据是2000000000000个tokens,还是用了1000000个人类新标注的数据。上下文长度由2048提升为4096。 本教程提供两种下载方式: 1官方下载脚本下载 2hugging face网站下载 官网资格申请 …...

C高级【day4】

思维导图&#xff1a; 写一个函数&#xff0c;获取用户的uid和gid并使用变量接收&#xff1a; #!/bin/bashfunction get_uid {my_uidid -umy_gidid -g }get_uid echo "当前用户的UID&#xff1a;$my_uid" echo "当前用户的GID&#xff1a;$my_gid"整理冒泡…...

【前端实习生备战秋招】—HTML 和 CSS面试题总结(一)

【前端实习生备战秋招】—HTML 和 CSS面试题总结&#xff08;一&#xff09; 1. 你做的页面在哪些流览器测试过&#xff1f;这些浏览器的内核分别是什么? IE:trident内核 Firefox&#xff1a;gecko内核 Safari:webkit内核 Opera:以前是presto内核&#xff0c;Opera现已改用Goo…...

【从零学习python 】02. 开发工具介绍

文章目录 编写Python代码一、常见的代码编辑工具二、运行Python程序三、Pycharm的下载和安装PyCharm的主要功能区域进阶案例 编写Python代码 根据我们之前介绍的知识&#xff0c;我们知道&#xff0c;所谓代码其实就是将一段普通文本按照一定的规范编写&#xff0c;然后交给电…...

Python:Spider爬虫工程化入门到进阶(2)使用Spider Admin Pro管理scrapy爬虫项目

Python&#xff1a;Spider爬虫工程化入门到进阶系列: Python&#xff1a;Spider爬虫工程化入门到进阶&#xff08;1&#xff09;创建Scrapy爬虫项目Python&#xff1a;Spider爬虫工程化入门到进阶&#xff08;2&#xff09;使用Spider Admin Pro管理scrapy爬虫项目 目录 1、使…...

CubeMap convert into Octahedral思路

看了一些介绍&#xff0c;大多都是如何采样Octahedral的&#xff0c;那么如何把cubemap转成为这个呢 首先&#xff0c;我们想想 Vec4 Sample(Vec3 direction) { // Some logicwait wait wait think about what weve got here UV UV UV! return SampleTexture(Image, UV); }这个…...

vue项目实战-脑图编辑管理系统kitymind百度脑图

前言 项目为前端vue项目&#xff0c;把kitymind百度脑图整合到前端vue项目中&#xff0c;显示了脑图的绘制&#xff0c;编辑&#xff0c;到处为json&#xff0c;png&#xff0c;text等格式的功能 文章末尾有相关的代码链接&#xff0c;代码只包含前端项目&#xff0c;在原始的…...

c++调用ffmpeg api录屏 并进行rtmp推流

代码及工程见https://download.csdn.net/download/daqinzl/88156528 开发工具&#xff1a;visual studio 2019 记得启动rtmp流媒体服务 nginx的rtmp服务见https://download.csdn.net/download/daqinzl/20478812 播放&#xff0c;采用ffmpeg工具集里的ffplay.exe, 执行命令 f…...

SQL分类及通用语法数据类型(超详细版)

一、SQL分类 SQL是结构化查询语言&#xff08;Structured Query Language&#xff09;的缩写。它是一种用于管理和操作关系型数据库系统的标准化语言。SQL分类如下&#xff1a; DDL: 数据定义语言&#xff0c;用来定义数据库对象&#xff08;数据库、表、字段&#xff09;DML:…...

配置Hive远程服务详细步骤

HiveServer2支持多客户端的并发和认证&#xff0c;为开放API客户端如JDBC、ODBC提供了更好的支持。 &#xff08;1&#xff09;修改hive-site.xml&#xff0c;在文件中添加以下内容&#xff1a; <property><name>hive.metastore.event.db.notification.api.auth&l…...

Java中实现图片和Base64的互相转化

文章目录 前言一、代码二、测试三、结果 前言 公司项目中用到了实名认证此&#xff0c;采用的第三方平台。后端中用到的单项功能为身份证信息人像对比功能&#xff0c;在写demo的过程中发现&#xff0c;它们所要求的图片信息为base64编码格式。 一、代码 package com.bajiao…...

视频添加字幕

1、依靠ffmpeg 命令 package zimu;import java.io.IOException;public class TestSrt {public static void main(String[] args) {String videoFile "/test/test1.mp4";String subtitleFile "/test/test1.SRT";String outputFile "/test/testout13…...

Vue VS React:两大前端框架的对比与分析

Vue和React是当前最流行的前端框架之一&#xff0c;它们都有着广泛的应用和开发者社区。下面是Vue和React之间的深度对比与分析&#xff1a; 学习曲线&#xff1a; Vue&#xff1a;Vue拥有简单直观的API和文档&#xff0c;对初学者友好。Vue的设计初衷是逐步增强的&#xff0c;…...