在 Axios 中,发起 HTTP 请求时你可以使用多种参数来配置请求的行为。以下是一些主要的参数:
1. url
- 描述:请求的 URL。
- 示例 :
axios.get('/api/users')
2. method
- 描述 :HTTP 请求的方法,可以是
GET
,POST
,PUT
,DELETE
等。 - 示例 :
axios({ method: 'post', url: '/api/users' })
- 默认值 :method没填那么
默认是get
3. data
-
描述 :请求体中的数据,通常在
POST
、PUT
、PATCH
请求中使用。 -
示例 :
javascriptaxios.post('/api/users', { name: 'John Doe', email: 'john.doe@example.com' });
4. params
-
描述 :URL 查询参数,通常在
GET
请求中使用。 -
示例 :
javascriptaxios.get('/api/users', { params: { page: 1, limit: 10 } });
5. headers
-
描述:自定义请求头,用于传递特定的信息。
-
示例 :
javascriptaxios.get('/api/users', { headers: { Authorization: 'Bearer your_token' } });
6. timeout
-
描述:请求超时时间,单位是毫秒。
-
示例 :
javascriptaxios.get('/api/users', { timeout: 5000 // 超过 5 秒请求失败 });
7. responseType
-
描述 :指定服务器响应的数据类型,例如
arraybuffer
,blob
,document
,json
,text
,stream
等。 -
示例 :
javascriptaxios.get('/api/data', { responseType: 'json' });
8. validateStatus
-
描述 :自定义用于判断响应状态码是否被视为成功的函数,默认为
status >= 200 && status < 300
。 -
示例 :
javascriptaxios.get('/api/data', { validateStatus: function (status) { return status < 500; // 只要状态码小于 500 就视为成功 } });
9. auth
-
描述 :用于 HTTP 基本身份验证,包含
username
和password
。 -
示例 :
javascriptaxios.get('/api/protected', { auth: { username: 'your_username', password: 'your_password' } });
10. withCredentials
-
描述 :指定是否跨域请求时发送 cookie 用于身份验证。默认值为
false
。 -
示例 :
javascriptaxios.get('/api/data', { withCredentials: true });
11. onUploadProgress
和 onDownloadProgress
-
描述:用于处理上传和下载进度的回调函数。
-
示例 :
javascriptaxios.post('/api/upload', formData, { onUploadProgress: progressEvent => { const percentage = Math.round((progressEvent.loaded * 100) / progressEvent.total); console.log(percentage); } });
这些参数可以组合使用,以满足你的请求需求。具体使用时可以根据需要进行选择和配置。