概述
Axios 是一个基于 Promise
的 HTTP 库,可以用在浏览器和 node.js
中。github开源地址https://github.com/axios/axios
安装
使用npm 安装
直接使用cdn
1
| <script src="https://unpkg.com/axios/dist/axios.min.js"></script>
|
或者去官网 下载axios ,
然后引用 axios.min.js
例子
为给定 ID 的 user 创建请求
1 2 3 4 5 6 7
| axios.get('/user?ID=12345') .then(function (response) { console.log(response); }) .catch(function (error) { console.log(error); });
|
GET 参数可以放到params里(推荐)
1 2 3 4 5 6 7 8 9 10 11
| axios.get('/user', { params: { ID: 12345 } }) .then(function (response) { console.log(response); }) .catch(function (error) { console.log(error); });
|
// 还可以使用ECMAScript 2017里的async/await,添加 async
keyword to your outer function/method.
1 2 3 4 5 6 7 8
| async function getUser() { try { const response = await axios.get('/user?ID=12345'); console.log(response); } catch (error) { console.error(error); } }
|
执行多个并发请求
1 2 3 4 5 6 7 8 9 10 11 12
| function getUserAccount() { return axios.get('/user/12345'); }
function getUserPermissions() { return axios.get('/user/12345/permissions'); }
axios.all([getUserAccount(), getUserPermissions()]) .then(axios.spread(function (acct, perms) { }));
|
axios API
可以通过向 axios
传递相关配置来创建请求
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
| axios({ method: 'post', url: '/user/12345', data: { firstName: 'Fred', lastName: 'Flintstone' } });
axios({ method:'get', url:'http://bit.ly/2mTM3nY', responseType:'stream' }) .then(function(response) { response.data.pipe(fs.createWriteStream('ada_lovelace.jpg')) });
|
请求配置项
下面是创建请求时可用的配置选项,注意只有 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
| { url: "/user",
method: "get",
baseURL: "https://some-domain.com/api/",
transformRequest: [function (data) {
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",
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,
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
| { data: {},
status: 200,
statusText: "OK",
headers: {},
config: {} }
|