设置公共请求参数_封装一个useFetch实现页面销毁取消请求

c511e20863789d7e815be86d85525bd7.png

前端业务经常会出现这样一类问题,当用户网速过慢或是其他特殊情况下,该页面的请求还未完成,用户就已经点击其他页面跳出去了。理想状态下请求也是应该终止掉的,所以我们应该想办法将请求和页面卸载关联在一起。

1 使用AbortController将请求终止。

文档地址:

AbortController​developer.mozilla.org
78e8fceb84d685a7c3311f9ac0cfaa2b.png

代码:

通过abortController.abort();可以取消正在进行的请求

//创建AbortController对象
const abortController = new AbortController();fetch(host + 'newsSelectContentByType?type=2', {// 这里传入 signal 进行关联signal: abortController.signal,
})
.then(response => response.json())
.then(res => {// 处理拿到的数据并渲染showData(res);//初始化的loading设为falsesetInitLoading(false);
})//这里我们设置三秒后取消请求
setTimeout(()=>{// 这里调用 abort 即可取消请求abortController.abort();        
},3000)

浏览器控制台Network设置网络十秒延迟

5bcafaa0358517e2836e4abd78ea9e84.png
设置延迟为10s

65759901422eed45fcf9316a4466fe7c.gif
请求在3s后就自动结束掉了

同理我们可以使用useRef来创建AbortController对象,同时在组件销毁时去执行方法,完成请求的取消,但是我们不可能在每一个页面都去写这么多代码,所以这里我们去封装一个useFetch hook。

新建一个UseFetch.js

同理我们的UseFetch不仅仅可以做这一个需求,我们可以根据我们的业务需要去封装更多的功能进去,比如说请求的loading以及拼接一些公共参数或是说做一个统一的错误处理

//自定义fetchhook  封装组件卸载自动结束未完成的请求功能和loading功能
import React, { useState, useEffect , useRef } from 'react';const useFetch = (url,args) => {//全局设定AbortControllerconst abortController = useRef();//loadingconst [loading,setLoading] = useState(false);//结果const [result,setResult] = useState();//开启请求的方法const beginFetch = ()=>{abortController.current = new AbortController();//开启loadingsetLoading(true);//拼接参数let argsStr = '';if(args!=''){for(let key in args) {argsStr += key + '=' + args[key] + '&';}argsStr = '?' + argsStr.substr(0, argsStr.length-1);}//请求fetch(url+argsStr, {// 这里传入 signal 进行关联signal: abortController.current.signal,}).then(response => response.json()).then(response => setResult(response)).finally(() => setLoading(false));//无论请求成功还是失败都强制结束loading}//组件卸载useEffect(()=>{//组件清除时终止请求return () => {abortController.current.abort()}},[])return{ result,loading,beginFetch }  
}export default useFetch;

使用useFetch

//将之前的页面数据请求根据useFetch做修改//result 拿到的数据  loading页面是否展示loading beiginFetch开始进行请求
const {result,loading,beginFetch} = useFetch(host + 'newsSelectContentByType',{type:2}
);//点击加载更多 直接通过beginFetch()方法去获取数据
const onLoadMore = () => {//设一个loading动画 先渲染空数据setListData(listData.concat([...new Array(3)].map(() => ({ loading: true, name: {} ,img:[,,,]}))))//因为这里拿数据很快 所以做一个暂停的动画展示beginFetch();
};//监控result变化 当result发生变化重写处理数据并渲染到页面上
useEffect(()=>{//处理数据并渲染showData(result);
},result)	

该useFetch主要封装了loading功能和自动结束请求功能,在路由发生切换,Tab 发生切换等场景下,被卸载掉的组件发出的请求会被终止掉,同时在请求开始和结束的情况下会自动判定loading的状态。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/338416.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

rx 异步执行耗时_使用rx-java的异步抽象

rx 异步执行耗时对我而言,使用Rx-java的一大好处是,无论底层调用是同步还是异步,因此代码看起来都完全相同,因此该条目的标题也是如此。 考虑一个非常简单的客户代码用例,它执行三个缓慢运行的调用并将结果合并到一个…

C语言中return的各种用法

按初学的理解,return的任务就是返回对应的参数,在外层函数中对这个参数做进一步处理。实际上return的用法不只这些。为调用的函数返回参数值此类应用最为普遍,通常是在一个具有返回值的函数中,返回一个参数值,这个返回…

代码内查找函数引用_叮~~二级操作题 excel常考函数大梳理

1.AND函数格式:AND(logical1,logical2…)功能:and函数是一个逻辑函数,表示同时满足多个条件。通常配合if函数做条件判断,得值为true或者是false。2.OR函数格式:OR(logical1,logical2…)功能:or函数是一个逻…

hazelcast入门教程_Hazelcast入门指南第6部分

hazelcast入门教程这是有关Hazelcast的一系列文章中的第六篇。 如果一个人没有看过过去的五年,请到表中的内容后 ,我创建赶上。 本地客户 在上一篇文章之后,我决定要去本地化。 是的,我将演示Hazelcast自己的Java客户端。 Java不…

总结C语言中的数组知识点

数组:只能存放一种数据类型,比如int类型的数组、float类型的数组,里面存放的数据称为“元素”。数组的定义:首先声明数组的类型,然后声明数组元素的个数,也就是定义需要多少存储空间。数组格式与初始化格式…

python学什么版本2020年_2020年了居然还有人在学Python?学python有什么用?

都2020年了居然还有人在学python?学python有什么用?真是气抖冷啊!想学习python的小伙伴,可以加裙595227871 领取免费的学习资料为什么选择python?1.行业人才的需求 在过去五年里,呈现出爆发性增长的趋势。今…

主要矛盾和次要矛盾_次要GC,主要GC与完整GC

主要矛盾和次要矛盾在使用Plumbr中的GC暂停检测功能时,我被迫通过大量有关该主题的文章,书籍和演示工作。 在整个旅程中,我多次对次要,主要和完全GC事件的使用(误用)感到困惑。 这导致了这篇博客文章&#…

action mutation 调用_Vuex源码学习(六)action和mutation如何被调用的(前置准备篇)...

module与moduleCollection你一定要会啊!Vuex源码学习(五)加工后的module在组件中使用vuex的dispatch和commit的时候,我们只要把action、mutation注册好,通过dispatch、commit调用一下方法名就可以做到。使用方式vue组件内//in vue componentt…

grunt 插件_从Grunt测试Grunt插件

grunt 插件编写针对grunt插件的测试结果比预期的要简单。 我需要运行多个任务配置,并想通过在主目录中键入grunt test来调用它们。 在第一个任务失败后,咕声通常会退出。 这使得不可能在主项目gruntfile中存储多个失败方案。 从那里运行它们将需要--for…

​嵌入式开发为什么选择C语言?

从语言特点来说C语言有出色的可移植性,能在多种不同体系结构的软/硬平台上运行。简洁紧凑,使用灵活的语法机制,并能直接访问硬件能够直接访问硬件的语言有:汇编和C语言汇编属于低级语言,难以完成一些复杂的功能&#x…

mysql 临时表 heap_mysql优化: 内存表和临时表

由于直接使用临时表来创建中间表,其速度不如人意,因而就有了把临时表建成内存表的想法。但内存表和临时表的区别且并不熟悉,需要查找资料了。一开始以为临时表是创建后存在,当连接断开时临时表就会被删除,即临时表是存…

序列化与反序列化的单例模式_序列化代理模式

序列化与反序列化的单例模式在上一篇文章中 ,我谈到了一般的序列化。 这是更加集中的内容,并提供了一个细节: 序列化代理模式 。 这是处理序列化中许多问题的一种好方法,通常是最好的方法。 如果开发人员只想了解这一主题&#xf…

图解C语言的希尔排序

希尔排序是插入排序的一种,又称“缩小增量排序”,希尔排序是直接插入排序算法的一种更高效的改进版本。希尔排序的基本思想设等待排序等元素序列有n个元素,首先取一个整数increment(小于n)作为间隔将全部元素分为n/inc…

给oim_对OIM Web(UI)层进行压力测试

给oimOracle IDM中的默认配置保留20个专用于服务前端(UI)请求的线程 。 这基本上意味着应用程序服务器具有20个线程池,可用于为通过Web控制台(/ identity或/ sysadmin)访问OIM的用户提供服务。 对于Weblogic &#xf…

windows mysql is read only_mysql中Table is read only错误解决方法(转载)

下面来给各位同学介绍一下关于mysql中Table is read only的解决技巧,希望例子能帮助到各位。今天再我把数据库data 拷贝到linux 下运行程序 ”mysql中Table is read only的解决“ 出现这样的问题,查询资料。linux下执行如下命令即可#mysqladmin -u root…

C语言打印输出红色字体

除了Linux,在VS下也可以实现变色这一效果,先看下面的一段代码:#include int main(int argc,char **argv){ printf("\033[44;37;5m hello world\033[0m\n");return 0;}编译后运行上述代码,结果如下:可见&…

mysql g月份分组_PowerBI快捷键——视觉对象分组功能

PowerBI的2020年4月份更新虽然发布在5月份,但的确是提供了很多强大的功能。在以往,要选中多个视觉对象,往往需要按住CTRL键挨个单击选中,然后在进行下一步的分组或其他操作。但是在4月份更新中,PowerBI允许我们通过在画…

编译原理抽象语法树_平衡抽象原理

编译原理抽象语法树使代码复杂易读和理解的一件事是&#xff0c;方法内部的指令处于不同的抽象级别。 假设我们的应用程序仅允许登录用户查看其朋友的旅行。 如果用户不是朋友&#xff0c;则不会显示任何行程。 一个例子&#xff1a; public List<Trip> tripsByFriend…

谈谈单片机编程思想——状态机

玩单片机还可以&#xff0c;各个外设也都会驱动&#xff0c;但是如果让你完整的写一套代码时&#xff0c;却无逻辑与框架可言。这说明编程还处于比较低的水平&#xff0c;你需要学会一种好的编程框架或者一种编程思想&#xff01;比如模块化编程、状态机编程、分层思想等。本文…

C语言结构体使用与指针的理解

以前总有一种疑惑。为什么结构体的指针有的需要用分配空间&#xff1f;有的不需要分配空间呢&#xff1f;现在总结一下思路&#xff1a;一&#xff1a;关于结构体的定义问题&#xff1a;使用结构体一般会使用变量或者定义指针typedef struct{ int a; int b; }data;使用这个结构…