Axios 是一个基于 promise 的 HTTP 库,可以用在浏览器和 node.js 中
它可以用于执行 GET、POST、PUT、DELETE 等 HTTP 请求,支持请求和响应的拦截、取消请求等高级功能,提供了一种优雅、简洁的方式来处理 HTTP 请求。在前后端交互、接口调用等场景中,Axios 是一个非常常用的工具库
安装
1 <script src="https://unpkg.com/axios/dist/axios.min.js" ></script>
axios API 可以通过向 axios 传递相关配置来创建请求
1 2 3 4 5 6 7 8 9 axios ({ method : 'post' , url : '/user/12345' , data : { firstName : 'Fred' , lastName : 'Flintstone' } });
方法别名 为方便起见,为所有支持的请求方法提供了别名
axios.request(config)
axios.get(url[, config])
axios.delete(url[, config])
axios.head(url[, config])
axios.options(url[, config])
axios.post(url[, data[, config]])
axios.put(url[, data[, config]])
axios.patch(url[, data[, config]])
注意:在使用别名方法时,url、method、data 这些属性都不必在配置中指定
创建实例 可以使用自定义配置新建一个 axios 实例
1 2 3 4 5 const instance = axios.create ({ baseURL : 'https://some-domain.com/api/' , timeout : 1000 , headers : {'X-Custom-Header' : 'foobar' } });
请求配置 这些是创建请求时可以用的配置选项。只有 url 是必需的。如果没有指定 method,请求将默认使用 get 方法
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 { url : '/user' , method : 'get' , baseURL : 'https://some-domain.com/api/' , transformRequest : [function (data, headers ) { return data; }], transformResponse : [function (data ) { return data; }], headers : {'X-Requested-With' : 'XMLHttpRequest' }, params : { ID : 12345 }, paramsSerializer : function (params ) { return Qs .stringify (params, {arrayFormat : 'brackets' }) }, data : { firstName : 'Fred' }, timeout : 1000 , withCredentials : false , adapter : function (config ) { }, auth : { username : 'janedoe' , password : 's00pers3cret' }, responseType : 'json' , responseEncoding : 'utf8' , xsrfCookieName : 'XSRF-TOKEN' , xsrfHeaderName : 'X-XSRF-TOKEN' , onUploadProgress : function (progressEvent ) { }, onDownloadProgress : function (progressEvent ) { }, maxContentLength : 2000 , validateStatus : function (status ) { return status >= 200 && status < 300 ; }, maxRedirects : 5 , socketPath : null , httpAgent : new http.Agent ({ keepAlive : true }), httpsAgent : new https.Agent ({ keepAlive : true }), proxy : { host : '127.0.0.1' , port : 9000 , auth : { username : 'mikeymike' , password : 'rapunz3l' } }, cancelToken : new CancelToken (function (cancel ) { }) }
响应结构 某个请求的响应包含以下信息
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 { data : {}, status : 200 , statusText : 'OK' , headers : {}, config : {}, request : {} }
使用 then
时,你将接收下面这样的响应:
1 2 3 4 5 6 7 8 axios.get ('/user/12345' ) .then (function (response ) { console .log (response.data ); console .log (response.status ); console .log (response.statusText ); console .log (response.headers ); console .log (response.config ); });
默认值 你可以指定将被用在各个请求的配置默认值
全局的 axios 默认值 1 2 3 axios.defaults .baseURL = 'https://api.example.com' ; axios.defaults .headers .common ['Authorization' ] = AUTH_TOKEN ; axios.defaults .headers .post ['Content-Type' ] = 'application/x-www-form-urlencoded' ;
自定义实例默认值 1 2 3 4 5 6 7 const instance = axios.create ({ baseURL : 'https://api.example.com' }); instance.defaults .headers .common ['Authorization' ] = AUTH_TOKEN ;
配置的优先顺序 配置会以一个优先顺序进行合并。这个顺序是:在 lib/defaults.js
找到的库的默认值,然后是实例的 defaults
属性,最后是请求的 config
参数。后者将优先于前者
1 2 3 4 5 6 7 8 9 10 11 12 var instance = axios.create ();instance.defaults .timeout = 2500 ; instance.get ('/longRequest' , { timeout : 5000 });
拦截器 在请求或响应被 then
或 catch
处理前拦截它们
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 axios.interceptors .request .use (function (config ) { return config; }, function (error ) { return Promise .reject (error); }); axios.interceptors .response .use (function (response ) { return response; }, function (error ) { return Promise .reject (error); });
如果你想在稍后移除拦截器,可以这样:
1 2 const myInterceptor = axios.interceptors .request .use (function ( ) {});axios.interceptors .request .eject (myInterceptor);
可以为自定义 axios 实例添加拦截器
1 2 const instance = axios.create ();instance.interceptors .request .use (function ( ) {});
取消请求 使用 cancel token
取消请求。可以使用 CancelToken.source
工厂方法创建 cancel token
,像这样:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 const CancelToken = axios.CancelToken ;const source = CancelToken .source ();axios.get ('/user/12345' , { cancelToken : source.token }).catch (function (thrown ) { if (axios.isCancel (thrown)) { console .log ('Request canceled' , thrown.message ); } else { } }); axios.post ('/user/12345' , { name : 'new name' }, { cancelToken : source.token }) source.cancel ('Operation canceled by the user.' );
还可以通过传递一个 executor
函数到 CancelToken
的构造函数来创建 cancel token
:
1 2 3 4 5 6 7 8 9 10 11 12 const CancelToken = axios.CancelToken ;let cancel;axios.get ('/user/12345' , { cancelToken : new CancelToken (function executor (c ) { cancel = c; }) }); cancel ();
注意: 可以使用同一个 cancel token 取消多个请求