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ř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 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>
Při použití JSON.parse()
na JSON odvozeném z pole bude metoda vracet pole JavaScript namísto objektu JavaScript.
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>
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ř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ř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 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ř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()
.