下载鸥 > 网站下载 > 开发教程 > JS/JQuery

js的fetch函数怎么用?

48 2024-06-08 02:00:58

收藏
js的fetch函数怎么用?
在JavaScript中,fetch 是一个用于发起网络请求(通常是HTTP或HTTPS请求)的现代API。这个API提供了一个简单、直观的方式来获取(或发送)网络资源。
 

基本用法

fetch 函数接收一个URL作为参数,并返回一个 Promise 对象,这个 Promise 在请求完成(无论是成功还是失败)时解析。
 

代码示例

fetch('https://baidu.com/')  
  .then(response => {  
    // 请求成功时,response是一个Response对象  
    // 你可以在这里检查HTTP状态码,解析响应体等  
    console.log(response.status);// 输出HTTP状态码,如200 404
    if (!response.ok) {  
      throw new Error('Network response was not ok');  
    }  
    return response.json(); // 或者response.text(), response.blob()等  
  })  
  .then(data => {  
    // 如果解析成功,data是解析后的数据(例如JSON对象)  
    console.log(data);  
  })  
  .catch(error => {  
    // 请求失败时,会在这里捕获错误  
    console.error('Fetch Error:', error);  
  });

fetch 的特点

基于Promise:fetch 返回的是一个 Promise 对象,这使得异步操作更加简洁和易于管理。
返回Response对象:fetch 的 then 方法接收到的第一个参数是一个 Response 对象,它包含了请求的各种信息,如状态码、状态消息、响应头等。
不自动解析响应体:与 XMLHttpRequest 不同,fetch 不会自动解析响应体。你需要调用 Response 对象上的方法(如 json(), text(), blob() 等)来解析响应体。
默认不带凭据:默认情况下,fetch 不会发送跨站请求的凭据(如cookies、HTTP认证及客户端SSL证明等)。如果你需要发送凭据,可以在 fetch 的第二个参数(一个配置对象)中设置 credentials: 'include'。
不会阻止页面加载:与 XMLHttpRequest 不同,fetch 在浏览器中的行为不会阻止页面的加载或解析。这是因为它基于 Promise,而 Promise 的特性之一就是它们不会阻塞代码的执行。
不支持超时和取消:原生的 fetch API 不支持设置请求超时或取消请求。但是,你可以通过一些技术手段(如使用 AbortController API)来实现这些功能。
 

附注

由于 fetch 是基于Promise的,所以你需要确保你的代码环境支持Promise。当然,主流浏览器已经普遍支持Promise。
在处理响应时,一定要检查 response.ok(它相当于检查 response.status 是否在200-299之间)。因为即使请求成功发出并收到响应,响应的状态码也可能表示错误(如404、500等)。
在解析响应体时,如果响应的内容类型与你使用的解析方法不匹配(例如,你尝试用 json() 解析一个文本文件),那么解析会失败并抛出一个错误。

本文地址:https://xzo.com.cn/develop/js/1240.html

有帮助,很赞!

信息来源:下载鸥
导出教程 下载word版教程
发表评论 共有条评论
关于JS/JQuery


JavaScript(简称“JS”) 是一种具有函数优先的轻量级,解释型或即时编译型的编程语言。JavaScript 基于原型编程、多范式的动态脚本语言,并且支持面向对象、命令式和声明式(如函数式编程)风格。

JavaScript十分强大,不管是前端页面开发、视觉动态渲染、数据交互还是后端逻辑处理,都可以通过JS实现。虽然它是作为开发Web页面的脚本语言而出名,但是它也被用到了很多非浏览器环境中。

推荐JS/JQuery开发教程
JavaScript过滤XSS攻击方法
JavaScript过滤XSS攻击方法

什么是XSS?XSS(Cross Site Scripting),跨站脚本攻击,是一种允许攻击者在另外一个...

1 320
jQuery怎样监听鼠标滚动是向上还是向下的状态?
jQuery怎样监听鼠标滚动是向上还是向下的状态?

知乎鼠标向下滚动显示文章标题,向上滚动显示栏目;又或者向下滚动到底部时异步...

0 502
Superslide响应式页面直接应用手机端技巧介绍
Superslide响应式页面直接应用手机端技巧介绍

如果是响应式网站,那么用superslide做轮播图需要做两个,这无疑是非常不方便的...

1 422
JS点击复制data-*属性(支持多个元素)
JS点击复制data-*属性(支持多个元素)

分享一段js原生点击复制data-*属性的源码,根据onclick事件触发,复制当前元素...

0 337
swiper轮播图空白案例记录
swiper轮播图空白案例记录

今天鸥哥在用swiper做轮播图时,轮播效果虽然没问题,但只显示第一张,后面的图片...

0 334
js网站视频播放器ckplayer和dplayer优缺点分析
js网站视频播放器ckplayer和dplayer优缺点分析

dplayer和ckplayer都是非常流行的web视频播放器,二者都占有相当大的用户市场...

0 1454
JS判断苹果iPhone与iPad、安卓设备类型适配
JS判断苹果iPhone与iPad、安卓设备类型适配

在网站开发的过程中,一些涉及到资源下载的网站会通过判断不同系统手机来展示...

3 613
JS获取浏览器语言(中英文多语言站)并自动跳转代码
JS获取浏览器语言(中英文多语言站)并自动跳转代码

如果是多语言站点,主动获取浏览器默认语言并自动进行跳转可以有效降低跳出率...

0 851
推荐插件
帝国cms网站会员登录与退出历史记录日志插件
帝国cms网站会员登录与退出历史记录日志插件

帝国cms默认只有上次登录时间与ip,没有一个记录清单,所以今天,我们分享这个帝...

0 279
帝国CMS内网用户静态站点文章访客统计插件
帝国CMS内网用户静态站点文章访客统计插件

本插件适用于内网用户,可查看单篇文章访问者ip地址。如果添加访问者ip组,可查...

0 459
帝国cms百度AI黑白图像上色api接口对接插件
帝国cms百度AI黑白图像上色api接口对接插件

百度开放了系列AI功能api如图像上色、图像去雾、图像修复、无损放大、清晰...

0 328
帝国cms自动给正文关键词添加tag内链
帝国cms自动给正文关键词添加tag内链

帝国cms有自带的给关键词添加内链功能,但需要手动添加关键词,容易出现疏漏和...

0 669
帝国cms百度、必应bing、神马推送增强收录三合一插件
帝国cms百度、必应bing、神马推送增强收录三合一插件

因客户需要一键推送到多平台,下载鸥开发了这款一键推送至百度、必应、神马插...

0 31
帝国cms自动生成文章新闻目录插件下载
帝国cms自动生成文章新闻目录插件下载

用户体验是我们的需求,百度蜘蛛的认可更是我们的需求。毕竟,没有收录排名,何来...

0 981
帝国cms百度AI图像清晰度增强api接口对接插件
帝国cms百度AI图像清晰度增强api接口对接插件

通过本插件,可以实现帝国cms网站对接百度云api实现图像清晰度增强的功能。经...

0 417
帝国cms纳米数据接口(足球比赛中最新数据)
帝国cms纳米数据接口(足球比赛中最新数据)

帝国cms 对接纳米数据(www.nami.com)接口,本接口主要接收、整理足球比赛实时数...

0 184
客服QQ:341553759
扫码咨询 常见问题 >
官方交流群:90432500
点击加入