JSON-server


Indholdsfortegnelse

    Vis indholdsfortegnelse


En almindelig brug af JSON er at udveksle data til/fra en webserver.

Når du modtager data fra en webserver, er dataene altid en streng.

Parse dataene med JSON.parse(), og dataene bliver et JavaScript-objekt.


Sender data

Hvis du har data gemt i et JavaScript-objekt, kan du konvertere objektet ind i JSON, og send det til en server:

Eksempel

 const myObj = {name: "John", 
  age: 31, city: "New York"};
const myJSON = 
  JSON.stringify(myObj);
window.location = "demo_json.php?x=" + myJSON;

Prøv det selv →

<!DOCTYPE html>
<html>
<body>

<h2>Convert a JavaScript object into a JSON string, and send it to the server.</h2>

<script>
const myObj = { name: "John", age: 31, city: "New York" };
const myJSON = JSON.stringify(myObj);
window.location = "demo_json.php?x=" + myJSON;
</script>

</body>
</html>

Modtagelse af data

Hvis du modtager data i JSON-format, kan du nemt konvertere dem til et JavaScript objekt:

Eksempel

 const myJSON =
  '{"name":"John", 
  "age":31, "city":"New York"}';
const myObj = 
  JSON.parse(myJSON);
document.getElementById("demo").innerHTML = myObj.name;

Prøv det selv →

<!DOCTYPE html>
<html>
<body>

<h2>Convert a JSON string into a JavaScript object.</h2>

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

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

</body>
</html>

JSON fra en server

Du kan anmode om JSON fra serveren ved at bruge en AJAX-anmodning

Så længe svaret fra serveren er skrevet i JSON-format, kan du parse strengen til et JavaScript-objekt.

Eksempel

Brug XMLHttpRequest til at hente data fra serveren:

const xmlhttp = new XMLHttpRequest();
xmlhttp.onload = function() {
  const myObj = JSON.parse(this.responseText);
  document.getElementById("demo").innerHTML = myObj.name;
};
xmlhttp.open("GET", "json_demo.txt");
xmlhttp.send();

Prøv det selv →

<!DOCTYPE html>
<html>
<body>

<h2>Fetch a JSON file with XMLHttpRequest</h2>
<p id="demo"></p>

<script>
const xmlhttp = new XMLHttpRequest();
xmlhttp.onload = function() {
  const myObj = JSON.parse(this.responseText);
  document.getElementById("demo").innerHTML = myObj.name;
}
xmlhttp.open("GET", "json_demo.txt");
xmlhttp.send();
</script>

</body>
</html>

Tag et kig på json_demo.txt: https://basicit.org/js/json_demo.txt



Array som JSON

Når du bruger JSON.parse() på JSON afledt fra et array, vil metoden returnere et JavaScript-array i stedet for et JavaScript-objekt.

Eksempel

JSON returneres fra en server som et array:

const xmlhttp = new XMLHttpRequest();
xmlhttp.onload = function() {
  const myArr = JSON.parse(this.responseText);
  document.getElementById("demo").innerHTML = myArr[0];
  }
}
xmlhttp.open("GET", "json_demo_array.txt", true);
xmlhttp.send();

Prøv det selv →

<!DOCTYPE html>
<html>
<body>

<h2>Fetch a JSON file with XMLHttpRequest</h2>
<p>Content written as an JSON array will be converted into a JavaScript array.</p>
<p id="demo"></p>

<script>
const xmlhttp = new XMLHttpRequest();
xmlhttp.onload = function() {
  const myArr = JSON.parse(this.responseText);
  document.getElementById("demo").innerHTML = myArr[0];
}
xmlhttp.open("GET", "json_demo_array.txt", true);
xmlhttp.send();
</script>

</body>
</html>

Tag et kig på json_demo_array.txt: https://basicit.org/js/json_demo_array.txt