2017-11-17 12 views
0

でJSONのサブキー私はこのコードを持っているが、それはないプリントサブキーを行います....オブジェクト印刷する場合はJavaScript

for (var key in result) { 
     if (!result.hasOwnProperty(key)) continue; 
     var obj = result[key]; 
     for (var prop in obj) { 
      if (!obj.hasOwnProperty(prop)) continue; 
      alert(prop + " = " + obj[prop]); 
     } 
    } 

を取得:someKey [Objectオブジェクト]

私の結果(例):あなただけかどうかを確認する必要があるので、あなたは、再帰関数の代わりに、ネストされたfor in文としてあなたの関数を扱う場合、それは良いでしょう

[ { "branch_id": 992, "sale_id": 24422, "identifier": "", "emitter": { "id": 68, "tax_id": "", "address": { "street": "Carretera a buenavista km 21", "country_code": "MEX", } } } ]

+1

だけでなく 'result'を追加してください。 –

+3

'細部のそのレベルは表示されませんalert'は、あなたが使用する必要があります' console.log' –

+0

@ninaScholz [ { "BRANCH_ID":992、 "sale_id":24422、 "識別子": ""、 "エミッタ":{ "ID":68、 "tax_id": ""、 "アドレス":{ "通り": "のCarreteraブエナビスタキロ21"、 "COUNTRY_CODE": "MEX"、 } } } ] –

答えて

0

私はここで答えを見つけました。

Get all keys of a deep object in Javascript

function getDeepKeys(obj) { 
 
    var keys = []; 
 
    for (var key in obj) { 
 
     keys.push(key); 
 
     if (typeof obj[key] === "object") { 
 
      var subkeys = getDeepKeys(obj[key]); 
 
      keys = keys.concat(subkeys.map(function (subkey) { 
 
       return key + "." + subkey; 
 
      })); 
 
     } 
 
    } 
 
    return keys; 
 
} 
 
var data = [{ "branch_id": 992, "sale_id": 24422, "identifier": "", "emitter": { "id": 68, "tax_id": "", "address": { "street": "Carretera a buenavista km 21", "country_code": "MEX", } } }]; 
 

 
console.log(getDeepKeys(data));

0

R valueかのコードで、あなたが持っているので、再び機能をリコールするオブジェクトこの:

var json = { 
 
\t "key1": "value1", 
 
\t "key2": "value2", 
 
\t "key3": { 
 
    \t "sub_1_key1": "subvalue1", 
 
    \t "sub_1_key2": "subvalue2", 
 
    \t "sub_1_key3": "subvalue3", 
 
    "sub_1_key4": { 
 
    \t "sub_2_key1": "sub_2_value1" 
 
    } 
 
    }, 
 
}; 
 

 
var logger = document.getElementById('logs'); 
 

 
function goThroughJSON(json) { 
 
\t for (var attr in json) { 
 
    \t var value = json[attr]; 
 
    \t if (typeof value === 'object' && !(attr instanceof Array)) { 
 
    \t return goThroughJSON(value); 
 
    } 
 
    logger.innerHTML += attr + '<br>' 
 
    } 
 
} 
 

 
goThroughJSON(json);
<div id="logs"></div>

私は本当にあなたはそれがhelful見つける願っています。

+0

メインキーの名前が必要です...... key3とsub_1_key4 –

+0

ネストされたキー名だけが必要ですか? –

+0

メインキーとセカンダリキーの名前がす​​べて必要です。 –

0

再帰的アプローチを使用できます。任意のキーに対して、オブジェクト値が含まれている場合は、再び同じ関数を再度呼び出すことができます。

const data = [{ "branch_id": 992, "sale_id": 24422, "identifier": "", "emitter": { "id": 68, "tax_id": "", "address": { "street": "Carretera a buenavista km 21", "country_code": "MEX", } } } ]; 
 

 
const ObjectKey = o => { 
 
    Object.keys(o).forEach(k => { 
 
    if(typeof o[k] === 'object'){ 
 
     ObjectKey(o[k]); 
 
    } else { 
 
     console.log(k, " ", o[k]); 
 
    } 
 
    }); 
 
} 
 

 
data.forEach(o => { 
 
    ObjectKey(o); 
 
});

+0

メインキーとセカンダリキーの名前がす​​べて必要です。 –

関連する問題