2025年3月16日 星期日 甲辰(龙)年 月十五 设为首页 加入收藏
rss
您当前的位置:首页 > 计算机 > 编程开发 > JavaScript

介绍 5 个实用的 Ajax 库

时间:02-15来源:作者:点击数:22
CDSY,CDSY.XYZ

在这篇文章中,我们将介绍一些用于 AJAX 调用的最好的 JS 库,包括 jQuery,Axios 和 Fetch。欢迎查看代码示例! AJAX 是用来对服务器进行异步 HTTP 调用的一系列 web 开发技术客户端框架。 AJAX 即 Asynchronous JavaScript and XML(异步 JavaScript 和 XML)。AJAX 曾是 web 开发界的一个常见名称,许多流行的 JavaScript 小部件都是使用 AJAX 构建的。例如,有些特定的用户交互(如按下按钮)会异步调用到服务器,服务器会检索数据并将其返回给客户端 —— 所有这些都不需要重新加载网页。

AJAX 的现代化重新引入

JavaScript 已经进化了,现在我们使用前端库和 / 或如 React、Angular、Vue 等框架构建了动态的网站。AJAX 的概念也经历了重大变化,因为现代异步 JavaScript 调用涉及检索 JSON 而不是 XML。有很多库允许你从客户端应用程序对服务器进行异步调用。有些进入到浏览器标准,有些则有很大的用户基础,因为它们不但灵活而且易于使用。有些支持 promises,有些则使用回调。在本文中,我将介绍用于从服务器获取数据的前 5 个 AJAX 库。

Fetch API

Fetch API 是 XMLHttpRequest 的现代替代品,用于从服务器检索资源。与 XMLHttpRequest 不同的是,它具有更强大的功能集和更有意义的命名。基于其语法和结构,Fetch 不但灵活而且易于使用。但是,与其他 AJAX HTTP 库区别开来的是,它具有所有现代 Web 浏览器的支持。Fetch 遵循请求 - 响应的方法,也就是说,Fetch 提出请求并返回解析到 Response 对象的 promise。 你可以传递 Request 对象来获取,或者,也可以仅传递要获取的资源的 URL。下面的示例演示了使用 Fetch 创建简单的 GET 请求。

  • fetch('https://www.example.com', {
  • method: 'get'
  • })
  • .then(response => response.json())
  • .then(jsonData => console.log(jsonData))
  • .catch(err => {
  • //error block
  • })

正如你所看到的,Fetch 的 then 方法返回了一个响应对象,你可以使用一系列的 then 进行进一步的操作。我使用.json () 方法将响应转换为 JSON 并将其输出到控制台。 假如你需要 POST 表单数据或使用 Fetch 创建 AJAX 文件上传(link:https://cloudinary.com/blog/file_upload_with_ajax),将会怎么样?此时,除了 Fetch 之外,你还需要一个输入表单,并使用 FormData 库来存储表单对象。

  • var input = document.querySelector('input[type="file"]')
  • var data = new FormData()
  • data.append('file', input.files[0])
  • data.append('user', 'blizzerand')
  • fetch('/avatars', {
  • method: 'POST',
  • body: data
  • })

你可以在官方的 Mozilla web 文档(link:https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API)中阅读更多关于 Fetch API 的信息。

Axios

Axios(link:https://github.com/axios/axios) 是一个基于 XMLHttpRequest 而构建的现代 JavaScript 库,用于进行 AJAX 调用。它允许你从浏览器和服务器发出 HTTP 请求。此外,它还支持 ES6 原生的 Promise API。Axios 的其他突出特点包括:

  • 拦截请求和响应。
  • 使用 promise 转换请求和响应数据。
  • 自动转换 JSON 数据。
  • 取消实时请求。

要使用 Axios,你需要先安装它。

  • npm install axios

下面是一个演示 Axios 行动的基本例子。

  • // Make a request for a user with a given ID
  • axios.get('/user?ID=12345')
  • .then(function (response) {
  • console.log(response);
  • })
  • .catch(function (error) {
  • console.log(error);
  • });

与 Fetch 相比,Axios 的语法更简单。让我们做一些更复杂的事情,比如我们之前使用 Fetch 创建的 AJAX 文件上传器。

  • var data = new FormData();
  • data.append('foo', 'bar');
  • data.append('file', document.getElementById('file').files[0]);
  • var config = {
  • onUploadProgress: function(progressEvent) {
  • var percentCompleted = Math.round( (progressEvent.loaded * 100) / progressEvent.total );
  • }
  • };
  • axios.put('/upload/server', data, config)
  • .then(function (res) {
  • output.className = 'container';
  • output.innerHTML = res.data;
  • })
  • .catch(function (err) {
  • output.className = 'container text-danger';
  • output.innerHTML = err.message;
  • });

Axios 更具可读性。Axios 也非常受 React 和 Vue 等现代库的欢迎。

jQuery

jQuery 曾经是 JavaScript 中的一个前线库,用于处理从 AJAX 调用到操纵 DOM 内容的所有事情。虽然随着其他前端库的 “冲击”,其相关性有所降低,但你仍然可以使用 jQuery 来进行异步调用。 如果你之前使用过 jQuery,那么这可能是最简单的解决方案。但是,你将不得不导入整个 jQuery 库以使用 $.ajax 方法。虽然这个库有特定于域的方法,例如 $.getJSON,$.get 和 $.post,但是其语法并不像其他的 AJAX 库那么简单。以下代码用于编写基本的 GET 请求。

  • $.ajax({
  • url: '/users',
  • type: "GET",
  • dataType: "json",
  • success: function (data) {
  • console.log(data);
  • }
  • fail: function () {
  • console.log("Encountered an error")
  • }
  • });

jQuery 好的地方在于,如果你有疑问,那么你可以找到大量的支持和文档。我发现了很多使用 FormData () 和 jQuery 进行 AJAX 文件上传的例子。下面是最简单的方法:

  • var formData = new FormData();
  • formData.append('file', $('#file')[0].files[0]);
  • $.ajax({
  • url : 'upload.php',
  • type : 'POST',
  • data : formData,
  • processData: false, // tell jQuery not to process the data
  • contentType: false, // tell jQuery not to set contentType
  • success : function(data) {
  • console.log(data);
  • alert(data);
  • }
  • });

SuperAgent

SuperAgent 是一个轻量级和渐进式的 AJAX 库,更侧重于可读性和灵活性。SuperAgent 还拥有一个温和的学习曲线,不像其他库。它有一个针对 Node.js API 相同的模块。SuperAgent 有一个接受 GET、POST、PUT、DELETE 和 HEAD 等方法的请求对象。然后你可以调用.then (),.end () 或新的.await () 方法来处理响应。例如,以下代码为使用 SuperAgent 的简单 GET 请求。

  • request
  • .post('/api/pet')
  • .send({ name: 'Manny', species: 'cat' })
  • .set('X-API-Key', 'foobar')
  • .set('Accept', 'application/json')
  • .then(function(res) {
  • alert('yay got ' + JSON.stringify(res.body));
  • });

如果你想要做更多的事情,比如使用此 AJAX 库上传文件,那该怎么做呢? 同样超级 easy。

  • request
  • .post('/upload')
  • .field('user[name]', 'Tobi')
  • .field('user[email]', 'tobi@learnboost.com')
  • .field('friends[]', ['loki', 'jane'])
  • .attach('image', 'path/to/tobi.png')
  • .then(callback);

如果你有兴趣了解更多关于 SuperAgent 的信息(link:https://visionmedia.github.io/superagent/),那么它们有一系列很不错的文档来帮助你开始这个旅程。

Request—— 简化的 HTTP 客户端

Request 库(link:https://github.com/request/request)是进行 HTTP 调用最简单的方法之一。结构和语法与在 Node.js 中处理请求的方式非常相似。目前,该项目在 GitHub 上有 18K 个星,值得一提的是,它是可用的最流行的 HTTP 库之一。 下面是一个例子:

  • var request = require('request');
  • request('http://www.google.com', function (error, response, body) {
  • console.log('error:', error); // Print the error if one occurred
  • console.log('statusCode:', response && response.statusCode); // Print the response status code if a response was received
  • console.log('body:', body); // Print the HTML for the Google homepage.
  • });

结论

从客户端进行 HTTP 调用在十年前可不是一件容易的事。前端开发人员不得不依赖于难以使用和实现的 XMLHttpRequest。现代的库和 HTTP 客户端使得用户交互、动画、异步文件上传等前端功能变得更加简单。 我个人最喜欢的是 Axios,因为我觉得它更易读更赏心悦目。你也可以忠于 Fetch,因为它文档化良好且有标准化的解决方案。 你个人最喜欢的 AJAX 库是哪个? 欢迎各位分享你的看法。

CDSY,CDSY.XYZ
方便获取更多学习、工作、生活信息请关注本站微信公众号城东书院 微信服务号城东书院 微信订阅号
推荐内容
相关内容
栏目更新
栏目热门
本栏推荐