首页 » 网站推广 » php库ajax技巧_5 个顶级的 JavaScript Ajax 组件和库

php库ajax技巧_5 个顶级的 JavaScript Ajax 组件和库

访客 2024-12-07 0

扫一扫用手机浏览

文章目录 [+]

AJAX是用来对做事器进行异步HTTP调用的一系列web开拓技能客户端框架。
AJAX即Asynchronous JavaScript and XML(异步JavaScript和XML)。
AJAX曾是web开拓界的一个常见名称,许多盛行的JavaScript小部件都是利用AJAX构建的。
例如,有些特定的用户交互(如按下按钮)会异步调用到做事器,做事器会检索数据并将其返回给客户端——所有这些都不须要重新加载网页。

AJAX的当代化重新引入

php库ajax技巧_5 个顶级的 JavaScript Ajax 组件和库

JavaScript已经进化了,现在我们利用前端库和/或如React、Angular、Vue等框架构建了动态的网站。
AJAX的观点也经历了重大变革,由于当代异步JavaScript调用涉及检索JSON而不是XML。
有很多库许可你从客户端运用程序对做事器进行异步调用。
有些进入到浏览器标准,有些则有很大的用户根本,由于它们不但灵巧而且易于利用。
有些支持promises,有些则利用回调。
在本文中,我将先容用于从做事器获取数据的前5个AJAX库。

php库ajax技巧_5 个顶级的 JavaScript 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库是哪个? 欢迎各位分享你的意见。

标签:

相关文章

phpmysqli排序技巧_聊聊MySQL是若何处理排序的

它们的相同点是都会对字段进行排序,那查询语句中的排序是如何实现的呢?当利用的查询语句须要进行排序时有两种处理情形:当前记录本来便是...

网站推广 2024-12-09 阅读0 评论0