IT rekvalifikace s garancí práce. Seniorní programátoři vydělávají až 160 000 Kč/měsíc a rekvalifikace je prvním krokem. Zjisti, jak na to!
Hledáme nové posily do ITnetwork týmu. Podívej se na volné pozice a přidej se do nejagilnější firmy na trhu - Více informací.

Diskuze: JSON a procházení

Aktivity
Avatar
David Šabacký:11.1.2019 8:32

Ahoj,

potřeboval bych malinko pomoci. Mám JSON, který volám z adresy http://demo.signalk.org/…essels/self/ a protože se jedná o JSON, který nedělám, má několik úrovní a jeho obsah se mení potřebuju jednotlivé hodnoty číst pomocí smyčky.

můj kod:

var url = 'http://demo.signalk.org/signalk/v1/api/vessels/self/'
$.getJSON( url, function( data ) {


        $.each(data.navigation, function (key,value) {
        var klic = "data,navigation." + key + ".value";


        $table.append('<tr />');


        $table.append(klic, value);

        console.log(key,value);
    });

$('#main').append($table);

});

Zkusil jsem: Pokud do hodnoty proměnné klíč vložím celý obsah této hodnoty, např. data.navigati­on.speedThrou­ghWater.value, pak mi v $table.append(da­ta.navigation­.speedThroughWa­ter.value, value); vrací správnou hodnotu, ale pokud to udělám jako $table.append(klic, value);, pak je výstupem obsah proměnné klic.

Asi vím proč to je, ale jak z toho ven?

Moc díky za názory

David

 
Odpovědět
11.1.2019 8:32
Avatar

Člen
Avatar
:11.1.2019 12:16

Skús tak narýchlo toto:

var url = 'http://demo.signalk.org/signalk/v1/api/vessels/self/'

$.getJSON(url, function (data) {
  $.each(data.navigation, function (key, value) {
    var klic = data.navigation[key].value

    $table.append('<tr />')
    $table.append(klic, value)
    console.log(klic, value)
  })

  $('#main').append($table);
})
 
Nahoru Odpovědět
11.1.2019 12:16
Avatar
Odpovídá na
David Šabacký:11.1.2019 14:10

Zatím na první pohled to vypadá dobře, ještě to projdu dál a napíšu.

Moc díky

 
Nahoru Odpovědět
11.1.2019 14:10
Avatar
Roman Havránek:14.1.2019 23:25

Ale noták, proč takto? :-(

Proč ty české proměnné?
Sakra, když už radíte, tak ať je to alespoň dle best practices.

Co takhle to projít uplně jednoduše?

V objectu můžeš iterovat pomocí :

for (prop in object){
console.log(object[prop])
}

Není to takto jednodušší? :-)

Nahoru Odpovědět
14.1.2019 23:25
sleep();
Avatar
Šimon Raichl
Tvůrce
Avatar
Odpovídá na Roman Havránek
Šimon Raichl:15.1.2019 0:29

Nebo takto:

Object.keys(o).forEach(key => console.log(o[key]))

Pripadne pokud je treba vybrat jen hodnoty:

Object.values(o).forEach(value => console.log(value))

Nebo oboji: :D

Object.entries(o).forEach(entry => console.log(entry))
 
Nahoru Odpovědět
15.1.2019 0:29
Avatar
David Šabacký:19.1.2019 17:26

Ahoj lidi,

moc díky, je to lepší, ale stále to není ono.Jde o to, že v JSONu není přesně určeno na jaké úrovni je hodnota value. Někdy je to na úrovni
navigation.spe­edOverGround.va­lue, někdy na environment,win­d.speedApparen­t.value nekdy jen na první úrovni. Potřeboval bych najít způsob, jak otestovat, zda je value object, to jsem našel : if (typeof value === "object"), pokud ano, potom bych potřeboval do $.each(data, function (key, value) přidat za data ten poslední key (například navigation), případně takto pokračovat dále.

Pokusil jsem se vyrobit proměnnou např klic = data.key a tu zkusit dát do $.each(klic, function (key, value), ale to mi nechodí. Nemáte, prosím někdo nějakou radu?

Díky

David

PS:Object.valu­es(o).forEach(va­lue => console.log(value)) tohle jsem nerozchodil a tohle: for (prop in object){
console.log(ob­ject[prop])
} taky ne.

 
Nahoru Odpovědět
19.1.2019 17:26
Děláme co je v našich silách, aby byly zdejší diskuze co nejkvalitnější. Proto do nich také mohou přispívat pouze registrovaní členové. Pro zapojení do diskuze se přihlas. Pokud ještě nemáš účet, zaregistruj se, je to zdarma.

Zobrazeno 6 zpráv z 6.