Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xjbieke
axios
提交
a11cdf46
A
axios
项目概览
xjbieke
/
axios
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
A
axios
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
a11cdf46
编写于
9月 06, 2019
作者:
R
Rafael Renan Pacheco
提交者:
Felipe Martins
9月 06, 2019
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fixing custom config options (#2207)
- fixes #2203
上级
e50a08b2
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
36 addition
and
9 deletion
+36
-9
lib/core/mergeConfig.js
lib/core/mergeConfig.js
+31
-9
test/specs/core/mergeConfig.spec.js
test/specs/core/mergeConfig.spec.js
+5
-0
未找到文件。
lib/core/mergeConfig.js
浏览文件 @
a11cdf46
...
...
@@ -15,13 +15,23 @@ module.exports = function mergeConfig(config1, config2) {
config2
=
config2
||
{};
var
config
=
{};
utils
.
forEach
([
'
url
'
,
'
method
'
,
'
params
'
,
'
data
'
],
function
valueFromConfig2
(
prop
)
{
var
valueFromConfig2Keys
=
[
'
url
'
,
'
method
'
,
'
params
'
,
'
data
'
];
var
mergeDeepPropertiesKeys
=
[
'
headers
'
,
'
auth
'
,
'
proxy
'
];
var
defaultToConfig2Keys
=
[
'
baseURL
'
,
'
url
'
,
'
transformRequest
'
,
'
transformResponse
'
,
'
paramsSerializer
'
,
'
timeout
'
,
'
withCredentials
'
,
'
adapter
'
,
'
responseType
'
,
'
xsrfCookieName
'
,
'
xsrfHeaderName
'
,
'
onUploadProgress
'
,
'
onDownloadProgress
'
,
'
maxContentLength
'
,
'
validateStatus
'
,
'
maxRedirects
'
,
'
httpAgent
'
,
'
httpsAgent
'
,
'
cancelToken
'
,
'
socketPath
'
];
utils
.
forEach
(
valueFromConfig2Keys
,
function
valueFromConfig2
(
prop
)
{
if
(
typeof
config2
[
prop
]
!==
'
undefined
'
)
{
config
[
prop
]
=
config2
[
prop
];
}
});
utils
.
forEach
(
[
'
headers
'
,
'
auth
'
,
'
proxy
'
]
,
function
mergeDeepProperties
(
prop
)
{
utils
.
forEach
(
mergeDeepPropertiesKeys
,
function
mergeDeepProperties
(
prop
)
{
if
(
utils
.
isObject
(
config2
[
prop
]))
{
config
[
prop
]
=
utils
.
deepMerge
(
config1
[
prop
],
config2
[
prop
]);
}
else
if
(
typeof
config2
[
prop
]
!==
'
undefined
'
)
{
...
...
@@ -33,13 +43,25 @@ module.exports = function mergeConfig(config1, config2) {
}
});
utils
.
forEach
([
'
baseURL
'
,
'
url
'
,
'
transformRequest
'
,
'
transformResponse
'
,
'
paramsSerializer
'
,
'
timeout
'
,
'
withCredentials
'
,
'
adapter
'
,
'
responseType
'
,
'
xsrfCookieName
'
,
'
xsrfHeaderName
'
,
'
onUploadProgress
'
,
'
onDownloadProgress
'
,
'
maxContentLength
'
,
'
validateStatus
'
,
'
maxRedirects
'
,
'
httpAgent
'
,
'
httpsAgent
'
,
'
cancelToken
'
,
'
socketPath
'
],
function
defaultToConfig2
(
prop
)
{
utils
.
forEach
(
defaultToConfig2Keys
,
function
defaultToConfig2
(
prop
)
{
if
(
typeof
config2
[
prop
]
!==
'
undefined
'
)
{
config
[
prop
]
=
config2
[
prop
];
}
else
if
(
typeof
config1
[
prop
]
!==
'
undefined
'
)
{
config
[
prop
]
=
config1
[
prop
];
}
});
var
axiosKeys
=
valueFromConfig2Keys
.
concat
(
mergeDeepPropertiesKeys
)
.
concat
(
defaultToConfig2Keys
);
var
otherKeys
=
Object
.
keys
(
config2
)
.
filter
(
function
filterAxiosKeys
(
key
)
{
return
axiosKeys
.
indexOf
(
key
)
===
-
1
;
});
utils
.
forEach
(
otherKeys
,
function
otherKeysDefaultToConfig2
(
prop
)
{
if
(
typeof
config2
[
prop
]
!==
'
undefined
'
)
{
config
[
prop
]
=
config2
[
prop
];
}
else
if
(
typeof
config1
[
prop
]
!==
'
undefined
'
)
{
...
...
test/specs/core/mergeConfig.spec.js
浏览文件 @
a11cdf46
...
...
@@ -64,4 +64,9 @@ describe('core::mergeConfig', function() {
var
merged
=
mergeConfig
(
defaults
,
{
timeout
:
123
});
expect
(
merged
.
timeout
).
toEqual
(
123
);
});
it
(
'
should allow setting custom options
'
,
function
()
{
var
merged
=
mergeConfig
(
defaults
,
{
foo
:
'
bar
'
});
expect
(
merged
.
foo
).
toEqual
(
'
bar
'
);
});
});
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录