我想根据我检查的值获取键名列表。
这就是我所拥有的。
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',...]
请咨询。
答案 0 :(得分:4)
您可以通过检查拆分的字符串来过滤键。
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; }
答案 1 :(得分:2)
如果您使用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)