2017-02-27 7 views
1

JSONオブジェクトはさまざまな方法で返されますが、常にkeyです。どうすれば入手できますか?Javascript:JSONでキーとその値を確認

など。

"Records": { 
    "test": { 
     "key": "512" 
    } 
} 

、さらには、アレイ内の

"Records": { 
    "key": "112" 
} 

または

"Records": { 
    "test": { 
     "test2": [ 
      { 
       "key": "334" 
      } 
     ] 
    } 
} 

は、いくつかのオプションを試してみましたが、それでも私は(これは解決策になるmigth考える(

+0

を試すことができ、キーは常に文字列ですか? –

+0

親オブジェクトへの値または参照が必要ですか? –

+0

あなたはものを試したと言っています - それは何でしたか? –

答えて

1

私はあなたのためのコードを書くが、あなたのアイデアを与えることはありません、それは最初にのために、検索後

JSON.stringify(obj); 

を使用して文字列にしてJSONオブジェクトを変換、役立つかもしれindexOf()メソッドを使用するキー。 前の '{'と次の '}'文字列を抽出し、再度JSONオブジェクトにキャストします。 使用

var obj = JSON.parse(string); 

はその後

var value = obj.key 
+0

' /(?!^)( "key [^ \\] +?)(?=、)/ g'。ありがとう! –

2

を把握することはできませんasumingキーは常に文字列で、データのresについては気にしない)

const data = [`"Records": { 
 
    "test": { 
 
     "test2": [ 
 
      { 
 
       "key": "334", 
 
\t \t \t \t "key": "3343" 
 
      } 
 
     ] 
 
    } 
 
}`, `"Records": { 
 
    "test": { 
 
     "key": "512" 
 
    } 
 
}`, `"Records": { 
 
    "key": "112" 
 
}`] 
 

 
const getKeys = data => { 
 
    const keys = [] 
 
    const regex = /"key"\s*:\s*"(.*)"/g 
 
    let temp 
 
    while(temp = regex.exec(data)){ 
 
    keys.push(temp[1]) 
 
    } 
 
    return keys 
 
} 
 

 
for(let json of data){ 
 
    console.log(getKeys(json)) 
 
}

+0

これはパフォーマンスを低下させます。 –

+0

@ShobhitWaliaなぜそう思う? - それはあなたがデータの残りを気にしないと思います 'JSON.parse'も即時ではありません –

0

どのように私はそれを得ることができますか?

再帰的に!例えば

function getKey(rec) { 
    if (rec.key) return rec.key; 

    return getKey(rec[Object.keys(rec)[0]]); 
} 

https://jsfiddle.net/su42h2et/

0

は、あなたはそれでkeyを持つオブジェクトを取得するための反復や再帰的なアプローチを使用することができます。

function getKeyReference(object) { 
 
    function f(o) { 
 
     if (!o || typeof o !== 'object') { 
 
      return; 
 
     } 
 
     if ('key' in o) { 
 
      reference = o; 
 
      return true; 
 
     } 
 
     Object.keys(o).some(function (k) { 
 
      return f(o[k]); 
 
     }); 
 
    } 
 

 
    var reference; 
 
    f(object); 
 
    return reference; 
 
} 
 

 
var o1 = { Records: { key: "112" } }, 
 
    o2 = { Records: { test: { key: "512" } } }, 
 
    o3 = { Records: { test: { test2: [{ key: "334" }] } } }; 
 

 
console.log(getKeyReference(o1)); 
 
console.log(getKeyReference(o2)); 
 
console.log(getKeyReference(o3));

1

あなたはこの

const data = { 
 
\t "Records": { 
 
\t \t "key": "112" 
 
\t } 
 
}; 
 

 
const data2 = { 
 
\t "Records": { 
 
\t \t "test": { "key": "512" } 
 
\t } 
 
}; 
 

 
const data3 = { 
 
\t "Records": { 
 
\t \t "test": { 
 
\t \t \t "test2": [ 
 
\t \t \t \t { "key": "334" }, 
 
\t \t \t ] 
 
\t \t } 
 
\t } 
 
}; 
 

 
function searchKey(obj, key = 'key') { 
 
\t return Object.keys(obj).reduce((finalObj, objKey) => { 
 
\t \t if (objKey !== key) { 
 
\t \t \t return searchKey(obj[objKey]); 
 
\t \t } else { 
 
\t \t \t return finalObj = obj[objKey]; 
 
\t \t } 
 

 
\t }, []) 
 
} 
 

 
const result = searchKey(data); 
 
const result2 = searchKey(data2); 
 
const result3 = searchKey(data3); 
 
console.log(result); 
 
console.log(result2); 
 
console.log(result3);

関連する問題