【发布时间】:2023-01-09 21:08:33
【问题描述】:
我有一个在我的应用程序中使用的全局 axios 实例。我想针对特定请求在本地更新标头。但是标题更新正在更新全局默认值。我想了解执行此操作的最佳方法。目前我正在设法重置标题。还玩弄了深度克隆全局 axios 实例的想法。它只是感觉像是一个重要的功能,但找不到任何文档,除了一个关于子实例的 github 问题。 (https://github.com/axios/axios/issues/1170)
编辑:抱歉没有提供代码。这是我给出一个想法的设置:
以下是我的全局 axiosClient(在文件 apiClient.js 中),添加了一些拦截器(代码中未显示)。
const axiosClient = axios.create({
baseURL,
headers: {
Authorization: <bearer_token>,
'Content-Type': 'application/json',
.
}
});
在我的模块中,我导入相同的客户端来发出 api 请求:
import axiosClient from '../apiClient';
export function someRequest({ file }) {
let formData = new FormData();
formData.append('file', file);
const initHeader = axiosClient.defaults.headers['Content-Type'];
axiosClient.defaults.headers['Content-Type'] = 'multipart/form-data'; // I want to make this change only for the local instance
const request = axiosClient.post('parse-rebalance-data', formData);
axiosClient.defaults.headers['Content-Type'] = initHeader; //I have to reset the changes I made to the axiosClient
return request;
}
现在我的问题又是,(1) 我是否需要以这种 hacky 的方式来做,或者 (2) 我应该研究深度克隆本地副本,或者 (3) 是否有记录的方法来做这件事,我错过了.
【问题讨论】:
-
请提供足够的代码,以便其他人可以更好地理解或重现问题。
-
你试过什么,什么不起作用?代码会有所帮助。如果您正确地将标头传递给单个请求,它不应该更新全局标头,但在您提供一些代码之前很难判断。
-
@PureFunction 已更新
标签: javascript reactjs axios