5 个顶级的 javascript ajax 组件和库-mile米乐体育

本文由码农网 – 小峰原创翻译,转载请看清文末的转载要求,欢迎参与我们的付费投稿计划!

在这篇文章中,我们将介绍一些用于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,那么这可能是最简单的mile米乐体育的解决方案。但是,你将不得不导入整个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,因为它文档化良好且有标准化的mile米乐体育的解决方案。

你个人最喜欢的ajax库是哪个? 欢迎各位分享你的看法。

译文链接:http://www.codeceo.com/article/5-javascript-ajax-libs.html 英文原文:top javascript libraries for making ajax calls 翻译作者:码农网 – 小峰 [ 转载必须在正文中标注并保留原文链接、译文链接和译者等信息。]

展开全文
内容来源于互联网和用户投稿,文章中一旦含有米乐app官网登录的联系方式务必识别真假,本站仅做信息展示不承担任何相关责任,如有侵权或涉及法律问题请联系米乐app官网登录删除

最新文章

网站地图