Получить список имен ключей на основе значений - Javascript - PullRequest
2 голосов
/ 22 января 2020

Я хотел бы получить список имен ключей на основе значения, которое я проверяю.

Это то, что у меня есть.

const data = {
  "DE": "ARUN",
  "HI": "ARUN",
  "PR": "ARUN",
  "TX": "ARUN",
  "MA": "ARUN",
  "MD": "CHARLES,BRANDON,DAVID,ARUN",
  "IA": "ARUN",
  "ME": "ARUN",
  "ID": "ARUN",
  "MI": "ARUN",
  "UT": "ARUN",
  "MN": "ARUN",
  "MO": "ARUN",
  "IL": "ARUN",
  "IN": "ARUN",
  "MS": "ARUN",
  "MT": "ARUN",
  "AK": "ARUN",
  "AL": "ARUN",
  "VA": "ARUN",
  "AR": "ARUN",
  "AS": "ARUN",
  "VI": "ARUN",
  "NC": "ARUN",
  "ND": "ARUN",
  "NE": "ARUN",
  "RI": "ARUN",
  "AZ": "ARUN",
  "NH": "ARUN",
  "NJ": "ARUN",
  "VT": "ARUN",
  "NM": "ARUN",
  "FL": "ARUN",
  "NV": "ARUN",
  "WA": "ARUN",
  "NY": "ARUN",
  "SC": "ARUN",
  "SD": "ARUN",
  "WI": "ARUN",
  "OH": "ARUN",
  "GA": "ARUN",
  "OK": "ARUN",
  "CA": "ARUN",
  "WV": "ARUN",
  "WY": "ARUN",
  "OR": "ARUN",
  "KS": "ARUN",
  "CM": "ARUN",
  "CO": "ARUN",
  "GU": "ARUN",
  "KY": "ARUN",
  "CT": "ARUN",
  "PA": "ARUN",
  "LA": "ARUN",
  "TN": "ARUN",
  "DC": "ARUN"
}

const name = 'BRANDON'

const newMappedData = Object.keys(data).map(key => {
  return {
    [key]: data[key].split(',')
  }
})

const filteredData = newMappedData.filter(item => Object.values(item).includes(name))


console.log(filteredData)

В приведенном выше примере, когда мы вводим 'BRANDON', результат должен быть только ['MD'], а если 'ARUN', он должен давать мне ['DE', 'HI', 'PR',...]

Пожалуйста, совет.

Ответы [ 2 ]

4 голосов
/ 22 января 2020

Вы можете отфильтровать ключи, проверив разделенную строку.

const
    getKeys = value => Object.keys(data).filter(k => data[k].split(',').includes(value)),
    data = { DE: "ARUN", HI: "ARUN", PR: "ARUN", TX: "ARUN", MA: "ARUN", MD: "CHARLES,BRANDON,DAVID,ARUN", IA: "ARUN", ME: "ARUN", ID: "ARUN", MI: "ARUN", UT: "ARUN", MN: "ARUN", MO: "ARUN", IL: "ARUN", IN: "ARUN", MS: "ARUN", MT: "ARUN", AK: "ARUN", AL: "ARUN", VA: "ARUN", AR: "ARUN", AS: "ARUN", VI: "ARUN", NC: "ARUN", ND: "ARUN", NE: "ARUN", RI: "ARUN", AZ: "ARUN", NH: "ARUN", NJ: "ARUN", VT: "ARUN", NM: "ARUN", FL: "ARUN", NV: "ARUN", WA: "ARUN", NY: "ARUN", SC: "ARUN", SD: "ARUN", WI: "ARUN", OH: "ARUN", GA: "ARUN", OK: "ARUN", CA: "ARUN", WV: "ARUN", WY: "ARUN", OR: "ARUN", KS: "ARUN", CM: "ARUN", CO: "ARUN", GU: "ARUN", KY: "ARUN", CT: "ARUN", PA: "ARUN", LA: "ARUN", TN: "ARUN", DC: "ARUN" };

console.log(getKeys('BRANDON'));
console.log(getKeys('ARUN'));
.as-console-wrapper { max-height: 100% !important; top: 0; }
2 голосов
/ 22 января 2020

Если вы используете includes, вам даже не нужно split. Также вам не нужно использовать map для создания нового массива:

const data = {
  "DE": "ARUN",
  "HI": "ARUN",
  "PR": "ARUN",
  "TX": "ARUN",
  "MA": "ARUN",
  "MD": "CHARLES,BRANDON,DAVID,ARUN",
  "IA": "ARUN",
  "ME": "ARUN",
  "ID": "ARUN",
  "MI": "ARUN",
  "UT": "ARUN",
  "MN": "ARUN",
  "MO": "ARUN",
  "IL": "ARUN",
  "IN": "ARUN",
  "MS": "ARUN",
  "MT": "ARUN",
  "AK": "ARUN",
  "AL": "ARUN",
  "VA": "ARUN",
  "AR": "ARUN",
  "AS": "ARUN",
  "VI": "ARUN",
  "NC": "ARUN",
  "ND": "ARUN",
  "NE": "ARUN",
  "RI": "ARUN",
  "AZ": "ARUN",
  "NH": "ARUN",
  "NJ": "ARUN",
  "VT": "ARUN",
  "NM": "ARUN",
  "FL": "ARUN",
  "NV": "ARUN",
  "WA": "ARUN",
  "NY": "ARUN",
  "SC": "ARUN",
  "SD": "ARUN",
  "WI": "ARUN",
  "OH": "ARUN",
  "GA": "ARUN",
  "OK": "ARUN",
  "CA": "ARUN",
  "WV": "ARUN",
  "WY": "ARUN",
  "OR": "ARUN",
  "KS": "ARUN",
  "CM": "ARUN",
  "CO": "ARUN",
  "GU": "ARUN",
  "KY": "ARUN",
  "CT": "ARUN",
  "PA": "ARUN",
  "LA": "ARUN",
  "TN": "ARUN",
  "DC": "ARUN"
}

const name = 'BRANDON'

const filteredData = Object.keys(data).filter(key => data[key].includes(name))

console.log(filteredData)
...