首页 > 语言 > JavaScript > 正文

JavaScript fetch接口案例解析

2024-05-06 15:31:01
字体:
来源:转载
供稿:网友

在 AJAX 时代,进行 API 等网络请求都是通过 XMLHttpRequest 或者封装后的框架进行网络请求。

现在产生的 fetch 框架简直就是为了提供更加强大、高效的网络请求而生,虽然在目前会有一点浏览器兼容的问题,但是当我们进行 Hybrid App 开发的时候,如我之前介绍的 Ionic 和 React Native,都可以使用 fetch 进行完美的网络请求。

如果看网上的fetch教程,会首先对比XMLHttpRequest和fetch的优劣,然后引出一堆看了很快会忘记的内容(本人记性不好)。因此,我写一篇关于fetch的文章,为了自己看着方便,毕竟工作中用到的也就是一些很基础的点而已。

fetch,说白了,就是XMLHttpRequest的一种替代方案。如果有人问你,除了Ajax获取后台数据之外,还有没有其他的替代方案?

这是你就可以回答,除了XMLHttpRequest对象来获取后台的数据之外,还可以使用一种更优的解决方案fetch。

fetch的案例

下面我们来写第一个fetch获取后端数据的例子:

// 通过fetch获取百度的错误提示页面fetch('https://www.baidu.com/search/error.html') // 返回一个Promise对象 .then((res)=>{  return res.text() // res.text()是一个Promise对象 }) .then((res)=>{  console.log(res) // res是最终的结果 })

GET请求

GET请求初步

完成了helloworld,这个时候就要来认识一下GET请求如何处理了。

上面的helloworld中这是使用了第一个参数,其实fetch还可以提供第二个参数,就是用来传递一些初始化的信息。

这里如果要特别指明是GET请求,就要写成下面的形式:

// 通过fetch获取百度的错误提示页面fetch('https://www.baidu.com/search/error.html', {  method: 'GET' }) .then((res)=>{  return res.text() }) .then((res)=>{  console.log(res) })

GET请求的参数传递

GET请求中如果需要传递参数怎么办?这个时候,只能把参数写在URL上来进行传递了。

// 通过fetch获取百度的错误提示页面fetch('https://www.baidu.com/search/error.html?a=1&b=2', { // 在URL中写上传递的参数  method: 'GET' }) .then((res)=>{  return res.text() }) .then((res)=>{  console.log(res) })

POST请求

与GET请求类似,POST请求的指定也是在fetch的第二个参数中:

// 通过fetch获取百度的错误提示页面fetch('https://www.baidu.com/search/error.html', {  method: 'POST' // 指定是POST请求 }) .then((res)=>{  return res.text() }) .then((res)=>{  console.log(res) })

POST请求参数的传递

众所周知,POST请求的参数,一定不能放在URL中,这样做的目的是防止信息泄露。

// 通过fetch获取百度的错误提示页面fetch('https://www.baidu.com/search/error.html', {  method: 'POST',  body: new URLSearchParams([["foo", 1],["bar", 2]]).toString() // 这里是请求对象 }) .then((res)=>{  return res.text() }) .then((res)=>{  console.log(res) })            
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选