JSON.parse()


Obsah

    Zobrazit obsah


Běžným použitím JSON je výměna dat do/z webového serveru.

Při příjmu dat z webového serveru jsou data vždy řetězec.

Analyzujte data pomocí JSON.parse() a data se stanou objektem JavaScriptu.


Příklad - Analýza JSON

Představte si, že jsme obdrželi tento text z webového serveru:

'{"name":"John", "age":30, "city":"New York"}'

Pomocí funkce JavaScriptu JSON.parse() převeďte text na objekt JavaScript:

const obj = JSON.parse('{"name":"John", "age":30, "city":"New 
  York"}');
  

Ujistěte se, že je text ve formátu JSON, jinak se zobrazí chyba syntaxe.

Použijte na své stránce objekt JavaScript:

Příklad

<p id="demo"></p>

<script>
document.getElementById("demo").innerHTML = obj.name;
</script>

Zkuste to sami →

<!DOCTYPE html>
<html>
<body>

<h2>Creating an Object from a JSON String</h2>

<p id="demo"></p>

<script>
const txt = '{"name":"John", "age":30, "city":"New York"}'
const obj = JSON.parse(txt);
document.getElementById("demo").innerHTML = obj.name + ", " + obj.age;
</script>

</body>
</html>

Pole jako JSON

Při použití JSON.parse() na JSON odvozeném z pole bude metoda vracet pole JavaScript namísto objektu JavaScript.

Příklad

const text = '["Ford", "BMW", "Audi", "Fiat"]';
const myArr = JSON.parse(text);

Zkuste to sami →

<!DOCTYPE html>
<html>
<body>

<h2>Parsing a JSON Array.</h2>
<p>Data written as an JSON array will be parsed into a JavaScript array.</p>
<p id="demo"></p>

<script>
const text = '[ "Ford", "BMW", "Audi", "Fiat" ]';
const myArr = JSON.parse(text);
document.getElementById("demo").innerHTML = myArr[0];
</script>

</body>
</html>


Výjimky

Analýza dat

Objekty Date nejsou v JSON povoleny.

Pokud potřebujete uvést datum, napište ho jako řetězec.

Později jej můžete převést zpět na objekt data:

Příklad

Převeďte řetězec na datum:

const text =
  '{"name":"John", "birth":"1986-12-14", "city":"New York"}';
  const obj = JSON.parse(text);
obj.birth = new Date(obj.birth);
  
document.getElementById("demo").innerHTML = obj.name + ", " + obj.birth;

Zkuste to sami →

<!DOCTYPE html>
<html>
<body>

<h2>Convert a string into a date object.</h2>
<p id="demo"></p>

<script>
const text = '{"name":"John", "birth":"1986-12-14", "city":"New York"}';
const obj = JSON.parse(text);
obj.birth = new Date(obj.birth);
document.getElementById("demo").innerHTML = obj.name + ", " + obj.birth; 
</script>

</body>
</html>

Nebo můžete použít druhý parametr funkce JSON.parse() s názvem reviver.

Parametr reviver je funkce, která kontroluje každou vlastnost, před vrácením hodnoty.

Příklad

Převeďte řetězec na datum pomocí funkce reviver:

const text =
  '{"name":"John", "birth":"1986-12-14", "city":"New York"}';
  const obj = JSON.parse(text, function (key, value) {
  if 
  (key == "birth") {
    return new 
  Date(value);
  } else {
    
  return value;
  }
});
  
document.getElementById("demo").innerHTML = obj.name + ", " + obj.birth;

Zkuste to sami →

<!DOCTYPE html>
<html>
<body>

<h2>Convert a string into a date object.</h2>

<p id="demo"></p>

<script>
const text = '{"name":"John", "birth":"1986-12-14", "city":"New York"}';
const obj = JSON.parse(text, function (key, value) {
  if (key == "birth") {
    return new Date(value);
  } else {
    return value;
  }
});
document.getElementById("demo").innerHTML = obj.name + ", " + obj.birth; 
</script>

</body>
</html>

Funkce analýzy

Funkce nejsou v JSON povoleny.

Pokud potřebujete zahrnout funkci, napište ji jako řetězec.

Později jej můžete převést zpět na funkci:

Příklad

Převeďte řetězec na funkci:

const text =
  '{"name":"John", "age":"function () {return 
  30;}", "city":"New York"}';
  const obj = JSON.parse(text);
obj.age = eval("(" + obj.age + ")");
  
document.getElementById("demo").innerHTML = obj.name + ", " + 
  obj.age();

Zkuste to sami →

<!DOCTYPE html>
<html>
<body>

<h2>Convert a string into a function.</h2>
<p id="demo"></p>

<script>
const text = '{"name":"John", "age":"function() {return 30;}", "city":"New York"}';
const obj = JSON.parse(text);
obj.age = eval("(" + obj.age + ")");
document.getElementById("demo").innerHTML = obj.name + ", " + obj.age(); 
</script>

</body>
</html>

Měli byste se vyhnout používání funkcí v JSON, funkce ztratí svůj rozsah, a k jejich převedení zpět na funkce byste museli použít eval().