热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

认识axios和axios在vue中的模块封装(笔记)

axios的全局配置和实例配置全局属性axios.defaults.baseURLhttp:localhost:9999APIaxios.defaults.timeout5创

axios的全局配置和实例

//配置全局属性
axios.defaults.baseURL='http://localhost:9999/API'
axios.defaults.timeout=5//创建axios的实例 只有使用这个实例的时候才会生效
let newVar = axios.create({baseUTL:'http://localhost/API',timeout:5000
})
//使用方式
newVar({url:''
})

axios的并发请求

//第一种方式
axios.all([axios.get('http://localhost:9999/API1')axios.get('http://localhost:9999/API2')
]).then(res=>{//请求成功响应的是一个数组console.log(res[0])console.log(res[1])
}).catch(err=>{console.log(err)
})

//第二种方式
axios.all([axios.get('http://localhost:9999/API1')axios.get('http://localhost:9999/API2')
]).then(axios.spread((res1,res2)=>{console.log(res1)console.log(res2)})
).catch(err=>{console.log(err)
})

axios的拦截器

axios.interceptors.request.use 请求拦截器
axios.interceptors.response.use 响应拦截器

axios给我们提供了两大类拦截器一种是请求方向的拦截(成功请求,失败的)

另一种是响应方向的(成功的,失败的)

拦截器的作用 用于我们在网络请求的时候在发起请求或者响应时对操作进行响应的处理

发起请求时可以添加网页加载的动画 使用token认证时

响应的时候可以进行相应的数据处理

//请求方向拦截器
axios.interceptors.request.use(config=>{console.log("进入请求拦截器")console.log(config)return config //一定要return放行
}),err=>{console.log("请求方向失败")console.log(err)
}axios.get('http://localhost:9999/API').then(res=>{console.log(res)
})

//响应方向拦截器
axios.interceptors.response.use({console.log("进入响应拦截器")console.log(config)return config //一定要return放行
}),err=>{console.log("响应方向失败")console.log(err)
}axios.get('http://localhost:9999/API').then(res=>{console.log(res)
})

axios在vue中的模块封装


第一种方式

//封装位置
import axios from 'axios'
export function request(config,success,faill){axios({url:config}).then(res=>{success(res)}).catch(err=>{fail(err)})
}//调用者位置
import { request } from './request.js'
request('http://localhost:9999/API',res=>{console.log(res)
},err=>{console.log(err)
})

第二种方式

//封装位置
import axios from 'axios'
export function request(config){
axios.defaults.baseURL="http://localhost:9999/API"axios(config.url).then(res=>{config.success(res)}).catch(err=>{config.fail(err)})
}//调用者位置
import { request } from './request.js'
request({url:'user',success:res=>{console.log(res)},fail:err=>{console.log(err)}
})

第三种方式

//封装的位置
import axios from 'axios'
export function request(config){return new Promise((resolve, reject)=>{let newVar = axios.create({baseURL:'http://localhost:9999/API',timeout:5000})newVar(config).then(res=>{resolve(res)}).catch(err=>{reject(err)})})
}//调用者位置
import { request } from './request.js'
request({url:'getAllStudent'
}).then(res=>{console.log(res)
}).catch(err=>{console.log(err)
})

第四种方式 (推荐使用)

//封装位置
import axios from 'axios'
export function request(config){let newVar = axios.create({baseURL:'http://localhost:9999/API',timeout:5000})return newVar(config)
}//调用者位置
import { request } from './request.js'
request({url:'getAllStudent'
}).then(res=>{console.log(res)
}).catch(err=>{console.log(err)
})

推荐阅读
  • 本文介绍了作者在开发过程中遇到的问题,即播放框架内容安全策略设置不起作用的错误。作者通过使用编译时依赖注入的方式解决了这个问题,并分享了解决方案。文章详细描述了问题的出现情况、错误输出内容以及解决方案的具体步骤。如果你也遇到了类似的问题,本文可能对你有一定的参考价值。 ... [详细]
  • 本文介绍了如何使用JSONObiect和Gson相关方法实现json数据与kotlin对象的相互转换。首先解释了JSON的概念和数据格式,然后详细介绍了相关API,包括JSONObject和Gson的使用方法。接着讲解了如何将json格式的字符串转换为kotlin对象或List,以及如何将kotlin对象转换为json字符串。最后提到了使用Map封装json对象的特殊情况。文章还对JSON和XML进行了比较,指出了JSON的优势和缺点。 ... [详细]
  • 使用nodejs爬取b站番剧数据,计算最佳追番推荐
    本文介绍了如何使用nodejs爬取b站番剧数据,并通过计算得出最佳追番推荐。通过调用相关接口获取番剧数据和评分数据,以及使用相应的算法进行计算。该方法可以帮助用户找到适合自己的番剧进行观看。 ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文介绍了在Mac上搭建php环境后无法使用localhost连接mysql的问题,并通过将localhost替换为127.0.0.1或本机IP解决了该问题。文章解释了localhost和127.0.0.1的区别,指出了使用socket方式连接导致连接失败的原因。此外,还提供了相关链接供读者深入了解。 ... [详细]
  • 如何查询zone下的表的信息
    本文介绍了如何通过TcaplusDB知识库查询zone下的表的信息。包括请求地址、GET请求参数说明、返回参数说明等内容。通过curl方法发起请求,并提供了请求示例。 ... [详细]
  • 模板引擎StringTemplate的使用方法和特点
    本文介绍了模板引擎StringTemplate的使用方法和特点,包括强制Model和View的分离、Lazy-Evaluation、Recursive enable等。同时,还介绍了StringTemplate语法中的属性和普通字符的使用方法,并提供了向模板填充属性的示例代码。 ... [详细]
  • 本文介绍了一个React Native新手在尝试将数据发布到服务器时遇到的问题,以及他的React Native代码和服务器端代码。他使用fetch方法将数据发送到服务器,但无法在服务器端读取/获取发布的数据。 ... [详细]
  • Android实战——jsoup实现网络爬虫,糗事百科项目的起步
    本文介绍了Android实战中使用jsoup实现网络爬虫的方法,以糗事百科项目为例。对于初学者来说,数据源的缺乏是做项目的最大烦恼之一。本文讲述了如何使用网络爬虫获取数据,并以糗事百科作为练手项目。同时,提到了使用jsoup需要结合前端基础知识,以及如果学过JS的话可以更轻松地使用该框架。 ... [详细]
  • Gitlab接入公司内部单点登录的安装和配置教程
    本文介绍了如何将公司内部的Gitlab系统接入单点登录服务,并提供了安装和配置的详细教程。通过使用oauth2协议,将原有的各子系统的独立登录统一迁移至单点登录。文章包括Gitlab的安装环境、版本号、编辑配置文件的步骤,并解决了在迁移过程中可能遇到的问题。 ... [详细]
  • 本文讨论了在使用PHP cURL发送POST请求时,请求体在node.js中没有定义的问题。作者尝试了多种解决方案,但仍然无法解决该问题。同时提供了当前PHP代码示例。 ... [详细]
  • 本文详细介绍了GetModuleFileName函数的用法,该函数可以用于获取当前模块所在的路径,方便进行文件操作和读取配置信息。文章通过示例代码和详细的解释,帮助读者理解和使用该函数。同时,还提供了相关的API函数声明和说明。 ... [详细]
  • SpringBoot uri统一权限管理的实现方法及步骤详解
    本文详细介绍了SpringBoot中实现uri统一权限管理的方法,包括表结构定义、自动统计URI并自动删除脏数据、程序启动加载等步骤。通过该方法可以提高系统的安全性,实现对系统任意接口的权限拦截验证。 ... [详细]
  • 本文介绍了Java后台Jsonp处理方法及其应用场景。首先解释了Jsonp是一个非官方的协议,它允许在服务器端通过Script tags返回至客户端,并通过javascript callback的形式实现跨域访问。然后介绍了JSON系统开发方法,它是一种面向数据结构的分析和设计方法,以活动为中心,将一连串的活动顺序组合成一个完整的工作进程。接着给出了一个客户端示例代码,使用了jQuery的ajax方法请求一个Jsonp数据。 ... [详细]
author-avatar
小池子的思密达
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有