Axios Bertha 。 2022-05-18 03:22 213阅读 0赞 * Axios * 使用 * 取消请求 * 并发请求 * 拦截器 * 自定义请求实例 # Axios # 基于Promise 用于浏览器和 nodejs 的与服务端通信库 特征 * 支持 Promise API * 拦截请求和响应 * 转换请求和响应数据 * 取消请求 * 自动转换JSON数据 使用 * CDN <script src="https://unpkg.com/axios@0.16.2/dist/axios.min.js"></script> * node install axios --save const http = require('axios') ## 使用 ## 需要的模块中引入使用 import axios from 'axios' 语法 返回值为promise 1. `axios(config)` 2. `axios[method](config)` 支持的请求方式 axios.get(url[, config]) axios.post(url[, data[, config]]) axios.delete(url[, config]) axios.head(url[, config]) axios.options(url[, config]) axios.put(url[, data[, config]]) axios.patch(url[, data[, config]]) * vue中使用 npm install axios vue-axios --save Vue.use(VueAxios, Axios) // 在组件中使用 this.$http[method]() ## 取消请求 ## // 创建取消请求令牌 const { CancelToken } = axios const source = CancelToken.source() axios.create({ // 配置 cancelToken: source.token, }); * 调用 source.cancel('操作被用户取消') * 捕获取消错误 http.get('user') .then() .catch((error) => { if (axios.isCancel(error)) { // 用户取消 } else { // 请求失败 } }) ## 并发请求 ## created () { function http1() { return http.get('user') } function http2() { return http.get('book') } } axios.all([http1(), http2()]) .then((result) => { // 两次请求成功才执行 then() console.log(result[0]) // http1 console.log(result[1]) // http2 }) axios.all([http1(), http2()]) // 使用 axios.spread 分割 .then(axios.spread((res1, res2) => { console.log(res1) // http1 console.log(res2) // http2 })) ## 拦截器 ## 全局拦截器 // 请求拦截 axios.interceptors.request.use( (config) => { // 在发送请求之前做某事 if (config.url.match('login')) { config.baseURL = 'https://oapi.dingtalk.com/'; } return config; }, (error) => { // 请求错误时做些事 return Promise.reject(error) } ); // 响应拦截 axios.interceptors.response.use( (result) => { return result; }, err => Promise.reject(err) ); 取消拦截 axios.interceptors.request.eject(myInterceptor) ## 自定义请求实例 ## 可以使用自定义配置新建一个 axios 实例 import axios from 'axios' import queryString from 'queryString' axios.create({ // 设置请求的服务器 URL url: '/user', // 设置请求方式,默认是 get method: 'get', // 将自动加在 `url` 前面,除非 `url` 是一个绝对 URL。 baseURL: 'https://some-domain.com/api/', // 允许在向服务器发送前,修改请求数据,只适合 PUT、POST 和 PATCH transformRequest: [function (data) { // 对 data 进行任意转换处理 return data; }], // 传递给 then/catch 前,允许修改响应数据 transformResponse: [function (data) { // 对 data 进行任意转换处理 return data; }], // 自定义请求头 headers: { 'content-type': 'application/x-www-form-urlencoded' }, // 设置查询字符串 params: { name: 'hannah' }, // `params` 序列化的函数 paramsSerializer: function(params) { return params }, // 请求主体数据, 只适用于这些请求方法 PUT, POST 和 PATCH data: { firstName: 'Fred' }, // 设置请求超时ms(0 表示无超时时间), 若超时,请求将被中断 timeout: 1000, // 跨域请求时是否需要使用凭证, 默认的 false withCredentials: false, // 允许自定义处理请求,以使测试更轻松 adapter: function (config) { // 返回一个 promise 并应用一个有效的响应 }, // 表示应该使用 HTTP 基础验证,并提供凭据,将覆写掉 `headers` 设置的自定义 `Authorization` auth: { username: 'janedoe', password: 's00pers3cret' }, // 表示服务器响应的数据类型, 默认 'json', // 可以是 'arraybuffer'、'blob'、'document'、'text'、'stream' responseType: 'json', // 用作 xsrf token 的值的cookie的名称,默认 'XSRF-TOKEN' xsrfCookieName: 'XSRF-TOKEN', // default // 承载 xsrf token 的值的 HTTP 头的名称, 默认 'X-XSRF-TOKEN' xsrfHeaderName: 'X-XSRF-TOKEN', // 允许为上传处理进度事件, 对原生进度事件的处理 onUploadProgress: function (progressEvent) { }, // 允许为下载处理进度事件 onDownloadProgress: function (progressEvent) { }, // 允许的响应内容的最大尺寸 maxContentLength: 2000, // 定义对于给定的HTTP 响应状态码是 resolve 或 reject validateStatus: function (status) { return status >= 200 && status < 300; // 默认的 }, // 定义在 node.js 中 follow 的最大重定向数目, 如果设置为0,将不会 follow 任何重定向 maxRedirects: 5, // 定义在执行 http 和 https 时使用的自定义代理。允许像这样配置选项: httpAgent: new http.Agent({ keepAlive: true }), // 默认不启用 httpsAgent: new https.Agent({ keepAlive: true }), // 定义代理服务器的主机名称和端口,覆写掉已有的通过使用 `header` 设置的自定义 `Proxy-Authorization` proxy: { host: '127.0.0.1', port: 9000, // HTTP 基础验证应当用于连接代理,并提供凭据 auth: : { username: 'mikeymike', password: 'rapunz3l' } }, // 指定用于取消请求的 cancel token cancelToken: new CancelToken(function (cancel) { }) })
相关 节流Axios_react-axios 适用于 React 框架的 Axios 组件,具有 child function callback。 在 render 阶段进行异步请求。 继承了 axios Myth丶恋晨/ 2023年09月25日 12:12/ 0 赞/ 72 阅读
相关 axios axios 是基于Promise 的http客户端,可以用于浏览器和node.js。 特点: 浏览器使用 XMLHttpRequests node.js使用http 你的名字/ 2023年06月16日 02:17/ 0 赞/ 18 阅读
相关 axios <script type="text/javascript" src="js/axios.js"></script> <script type="text/ 傷城~/ 2023年01月08日 04:25/ 0 赞/ 162 阅读
相关 Axios Axios > vue本身是不支持发送ajax请求,需要通过其它库来实现(vue1.0----->vue-resource、vue2.0---->axios),或者也可以 痛定思痛。/ 2022年10月29日 01:48/ 0 赞/ 155 阅读
相关 axios vue更新到2.0之后,作者就宣告不再对vue-resource更新,而是推荐的axios,前一段时间用了一下,现在说一下它的基本用法。 首先就是引入axios,如果你使用e 叁歲伎倆/ 2022年06月08日 12:11/ 0 赞/ 203 阅读
相关 axios 转自:https://www.jianshu.com/p/df464b26ae58 一、安装 1、 利用npm安装`npm install axios --save` 心已赠人/ 2022年05月29日 10:55/ 0 赞/ 233 阅读
相关 axios 转自:https://www.jianshu.com/p/df464b26ae58 一、安装 1、 利用npm安装`npm install axios 比眉伴天荒/ 2022年05月25日 13:28/ 0 赞/ 219 阅读
相关 Axios Axios简介 Axios 是一个基于 promise 的 HTTP 库,可以用在浏览器和 node.js 中,用来发送 HTTP 请求,其作用类似于jQuery 的 a 梦里梦外;/ 2021年11月09日 15:26/ 0 赞/ 340 阅读
相关 axios axios 一、什么是axios 二、写法 三、axios常用的API 1.get和delete方式传递参数 2.post和p 妖狐艹你老母/ 2021年09月07日 06:12/ 0 赞/ 464 阅读
还没有评论,来说两句吧...