javascript axios取消请求 亲测可以成功
const CancelToken = axios.CancelToken; let cancel; // 这个模拟接口写个sleep2秒 可以看到效果 axios.get('/moban/aass', { cancelToken: new CancelToken(function executor(c) { // An executor function receives a cancel function as a parameter cancel = c; }) }); // cancel the request setTimeout(function(){ // 取消请求 cancel(); },300)
javascript axios取消请求 亲测可以成功
慢慢看可以理解
const CancelToken = axios.CancelToken; // 从中获取令牌对象 const source = CancelToken.source(); console.log("source.token",source.token); // 发请求 axios.get('/moban/aass', { // 传递令牌 cancelToken: source.token }); setTimeout(function () { source.cancel(); },1000);
原理看下
// 创建Promise,返回放行开关cancel function source () { var cancel; var promise = new Promise(function (resolve) { cancel = resolve; }); return { cancel:cancel, token:promise } } // 发请求 function axios_get(config) { if (config.cancelToken) { config.cancelToken.then(function () { xhr.abort(); }) } } // 代码执行 var source = source(); axios_get({cancelToken:source.token}); setTimeout(function () { source.cancel(); // 5秒之后执行下一步操作 },5000)
其实原理就是把promise作为参数传入 把resolve 赋予变量 这个resolve就是取消请求的
如果遇到什么不懂的地方直接关注公众号留言(本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须在文章页面给出原文连接,否则保留追究法律责任的权利。)
作者:newmiracle
出处:https://www.cnblogs.com/newmiracle/
分类:
javascript
标签:
javascript
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 在鹅厂做java开发是什么体验
· 百万级群聊的设计实践
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
· 永远不要相信用户的输入:从 SQL 注入攻防看输入验证的重要性
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
2020-02-12 微信小程序 wx.navigateTo无法 跳转的原因