Difference between revisions of "DOM working with data"

From ProgZoo
Jump to navigation Jump to search
Line 25: Line 25:
</div>
</div>


== Get the details from the number ==
<div class=qu>
Each country has a bunch of data associated, for example:
Each country has a bunch of data associated, for example:
  area: 330803
  area: 330803
Line 37: Line 35:
  population: 30177000
  population: 30177000
  tld: ".my"
  tld: ".my"
== Show the population ==
<div class=qu>
<div class=imper>Alter your code so that the output matches the model answer.</div>
<div class=imper>Alter your code so that the output matches the model answer.</div>
<pre class=usr>
<pre class=usr>
Line 43: Line 45:
   .then((r)=>{
   .then((r)=>{
     let tgt = r[102];
     let tgt = r[102];
     document.body.innerHTML = `
     document.body.append(
  <div>${tgt.name}</div>
      tgt.name,' ',
  <div>${tgt.continent}</div>
      tgt.population);
  <div>${tgt.capital}</div>
    });
  <div>population: ${tgt.population}</div>
`;
  });
</pre>
</pre>
<pre class=ans>
<pre class=ans>
Line 56: Line 55:
   .then((r)=>{
   .then((r)=>{
     let tgt = r[102];
     let tgt = r[102];
     document.body.innerHTML = `
     document.body.append(
  <div>${tgt.name} (${tgt.continent})</div>
      tgt.name,' ',
  <div>${tgt.capital}</div>
      tgt.population);
  <div>population: ${tgt.population}</div>
    });
  <img src='${tgt.flag}' style='width:100px'/>
`;
  });
</pre>
</pre>
</div>
</div>
== List D contries ==
== List D contries ==
<div class=qu>
<div class=qu>

Revision as of 01:24, 22 August 2021


Get the name from the number

  • You can obtain data from the server using a fetch call.
  • In these examples you will be getting data from /worldl.json this is a list of 195 countries in json format
  • The program snippet shows the name of country 42.
  • Change it so it shows the name of country 50.
  • See if you can find your country.
fetch('/worldl.json')
  .then((r)=>r.json())
  .then((r)=>{
     let tgt = r[42];
     document.body.innerHTML = tgt.name;
  });
fetch('/worldl.json')
  .then((r)=>r.json())
  .then((r)=>{
     let tgt = r[50];
     document.body.innerHTML = tgt.name;
  });

Each country has a bunch of data associated, for example:

area: 330803
capital: "Kuala Lumpur"
continent: "Asia"
flag: "//upload.wikimedia.org/wikipedia/commons/6/66/Flag_of_Malaysia.svg"
gdp: 304726000000
id: 102
name: "Malaysia"
population: 30177000
tld: ".my"

Show the population

Alter your code so that the output matches the model answer.
fetch('/worldl.json')
  .then((r)=>r.json())
  .then((r)=>{
     let tgt = r[102];
     document.body.append(
       tgt.name,' ',
       tgt.population);
     });
fetch('/worldl.json')
  .then((r)=>r.json())
  .then((r)=>{
     let tgt = r[102];
     document.body.append(
       tgt.name,' ',
       tgt.population);
     });

List D contries

List all the countries beginning with D.
fetch('/worldl.json')
  .then((r)=>r.json())
  .then((r)=>{
     document.body.innerHTML
       = r.filter(x=> x.name.startsWith('D'))
        .map(x => `<div>${x.continent}</div>`)
        .join('');
  });
fetch('/worldl.json')
  .then((r)=>r.json())
  .then((r)=>{
     document.body.innerHTML = 
       r.filter(x => x.name.startsWith('D'))
        .map(x => `<div>${x.name}</div>`)
        .join('');
  });