首页 > 解决方案 > 如何在javascript中的JSON对象声明中跳过或将参数传递到子节点

问题描述

很抱歉成为 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
}

基本上,我想跳过键“测试”或从envName. 我包括了一个通配符*,但它不起作用。

标签: javascriptjqueryarraysjsonmaps

解决方案


您可以使用方括号来参数化环境:

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');
}


推荐阅读