Triko zdarma Triko zdarma
Spouštíme individuální výuku programování! Zaváděcí slevy 799 Kč 599 Kč/60 minut se zkušeným lektorem! Výuka osobně Praha a okolí nebo po Skype celá ČR. O termíny a slevu si pište na [email protected].
Extra 10 % bodů navíc a tričko zdarma při zadání kódu "TRIKO10"
Avatar
David Šabacký:11. ledna 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. ledna 8:32
Avatar
Vladislav Ladicky:11. ledna 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. ledna 12:16
Avatar
Odpovídá na Vladislav Ladicky
David Šabacký:11. ledna 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. ledna 14:10
Avatar
Roman Havránek:14. ledna 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. ledna 23:25
sleep();
Avatar
Šimon Raichl
Překladatel
Avatar
Odpovídá na Roman Havránek
Šimon Raichl:15. ledna 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. ledna 0:29
Avatar
David Šabacký:Včera 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 Včera 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.