5个顶级的javascriptajax组件和库(代码片段)

author author     2022-12-23     147

关键词:

在这篇文章中,我们将介绍一些用于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文件上传,将会怎么样?此时,除了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文档中阅读更多关于Fetch API的信息。

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的信息,那么它们有一系列很不错的文档来帮助你开始这个旅程。

Request——简化的HTTP客户端
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库是哪个? 欢迎各位分享你的看法。

vue实现组件通信的5中方式

通信种类1)父组件向子组件通信2)子组件向父组件通信3)隔代组件间通信4)兄弟组件间通信1、props1)通过一般属性实现父向子通信2)通过函数属性实现子向父通信3)缺点:隔代组件和兄弟组件间通信比较麻烦2、vue自定义事件1)vue内置实... 查看详情

关于java顶级父类

Java的顶级父类是?objectobject有哪几个自带的方法(最少说5个)1、clone2、equals3、hashCode4、getClass5、wait6、notify7、notiftAll8、toString 查看详情

关于java顶级父类

Java的顶级父类是?objectobject有哪几个自带的方法(最少说5个)1、clone2、equals3、hashCode4、getClass5、wait6、notify7、notiftAll8、toString 查看详情

关于java顶级父类

Java的顶级父类是?objectobject有哪几个自带的方法(最少说5个)1、clone2、equals3、hashCode4、getClass5、wait6、notify7、notiftAll8、toString 查看详情

javascriptajax基础--本文转载

什么是ajaxajax即“AsynchronousJavaScriptandXML”(异步JavaScript和XML),也就是无刷新数据读取。http请求首先需要了解http请求的方法(GET和POST)。GET用于获取数据。GET是在URL中传递数据,它的安全性低,容量低。POST用于上传数据。POST... 查看详情

vue顶级组件(代码片段)

快有时候懒的把一些通用组件写到template里面去,而业务中又需要用到,比如表示loading状态这样组件。如果是这样的组件,可以选择把组件手动初始化,让组件在整个app生命周期中始终保持活跃。如://a.jsimportVuefrom'vue'impo... 查看详情

python-tkinter组件之toplevel

参考技术AToplevel(顶级窗口)组件类似于Frame组件,但Toplevel组件是一个独立的顶级窗口,这种窗口通常拥有标题栏、边框等部件。Toplevel组件通常用在显示额外的窗口、对话框和其他弹出窗口上。在root窗口添加一个按钮用于创... 查看详情

影响几代产品人的宝典第2部开启预售!5折限量抢,产品人都需要一本

...——是什么原因让亚马逊、苹果、谷歌、奈飞和特斯拉等顶级科技公司持续创新并输出优秀的产品?它们真正的优势到底在哪里?说起来,这是第一部从产品负责人的角度,讲解顶级公司打造技术驱动型产品底层... 查看详情

docker应用之顶级命令(代码片段)

...Docker,以及Docker的安装,这次让我们进一步的使用Docker的顶级命令。注:本篇会有大量的命令5.Docker顶级命令使用docker命令就可以查看Docker客户端的所有顶级命令选项,下面的图片仅仅截取了一部分。主要说说的还是以下的几个... 查看详情

这5个前端组件库,可以让你放弃jqueryui

在建立Web应用时,通常都需要用到一些有用的UI组件。无论应用中需要的是日历,滑块,图形或其它用于提升或简化用户交互的组件,那么都面临两种选择:要么自己来创建这些组件,要么使用现有的组件功能。自行开发这些组... 查看详情

如何在 2 个组件之间进行通信 - 兄弟组件(Angular 1.5.8)

】如何在2个组件之间进行通信-兄弟组件(Angular1.5.8)【英文标题】:Howtocommunicatebetween2component-siblingcomponents(Angular1.5.8)【发布时间】:2017-07-1814:56:00【问题描述】:嘿,我有以下组件树:我有一个名为rules的根组件和两个名为rul... 查看详情

SVN 结帐时缺少框架和库,XCode 5

】SVN结帐时缺少框架和库,XCode5【英文标题】:FrameworksandLibrariesmissingontheSVNcheckout,XCode5【发布时间】:2014-02-0411:42:09【问题描述】:我从SVN签出一个版本,但是当我运行项目时,它显示链接器错误和缺少框架。我通过再次添加... 查看详情

推荐30个用于微服务的顶级工具

推荐30个用于微服务的顶级工具 http://www.infoq.com/cn/articles/30-tools-for-building-microservices关于微服务的好文章不计其数。对于那些一直没有亲历微服务或初次听到这个概念的人来说,这篇文章相当于把一份顶级的开源工具清单送... 查看详情

此图表中有多少个强连接组件?

请考虑以下图表。我可以区分4个强连接组件,但它们是5.我错过了哪一个?此外,节点可以在多个组件中共享吗?答案这5个组成部分是:左上角的节点右上角的节点左下方节点右下方节点其余的节点你认为组件实际上不是组件... 查看详情

6个顶级pythonnlp库的比较!

6个顶级PythonNLP库的比较! http://blog.itpub.net/31509949/viewspace-2212320/ 自然语言处理(NLP)如今越来越流行,在深度学习开发的背景下变得尤为引人注目。在人工智能领域中,自然语言处理(NLP)从文本中理解和提取重要信息... 查看详情

javascriptajax简单的调用(代码片段)

查看详情

盘点apache毕业的11个顶级项目

...求之后才可毕业。从孵化器里毕业的项目,要么独立成为顶级项目,要么成为其他顶级项目的子项目。为便于大家了解Apache孵化的标准,本文盘点了Apache从20 查看详情

被嘲笑ppt做的辣眼睛?4个顶级辅助工具帮你完美逆袭!

在职场中PPT做的好绝对可以加分,但是想要做好PPT可不是说说那么简单,因为它不像Word、Excel那样,填写固定的数据和内容就行,有的朋友不不仅做不好PPT,而且做出的PPT还有点“辣眼睛”!今天给大家分享制作PPT可以用到的5... 查看详情