很抱歉,您是JSON的菜鸟。我有一个要传递给调用JSON对象的参数。JSON:
{
"environments":{
"test":{
"on":true
}
}
}
上面,第二个节点test
是动态的,具体取决于您所处的环境。我想传递一个参数值,以便可以根据您的声明更改键(上面没有使用任何数组,这是我不能更改的第三方API)。
代码:
const envName = 'test' // This can be changed to 'uat' too
if(body.environments.test.on === true) //I need the 'test' to change or parameterised.
{
// Do something
}
[基本上,我想跳过键'test'或传递envName
中的值。我包含了通配符*
,但它不起作用。
您可以使用方括号参数化环境:
let body = {
"environments":{
"uat":{
"on":true
}
}
}
const envName = 'uat';
if(body.environments[envName].on === true)
{
console.log('true');
}
或Object.values()
执行通配符方案:
let body = {
"environments":{
"uat":{
"on":true
}
}
}
const envName = 'uat';
if(Object.values(body.environments).some(x => x.on === true))
{
console.log('true');
}
您可以使用for .. in
循环遍历body.environments
的嵌套元素,并检查on是否为true,像这样:
const body = {
"environments":{
"test":{
"on":true
}
}
}
for(let b in body.environments) {
if(body.environments[b].on) {
console.log(body.environments[b].on);
}
}