Difference between revisions of "DOM Working with data"

From ProgZoo
Jump to navigation Jump to search
Line 212: Line 212:
     document.body.innerHTML =
     document.body.innerHTML =
       r.filter(r=>r.area>1000000)
       r.filter(r=>r.area>1000000)
        .map(r=>`<div>${r.name}</div>`)
        .join('');
  });
</pre>
</div>
== Countries in Europe ==
<div class=qu>
<div class='imper'>Show list of countries where the continent is Europe.</div>
<pre class=usr>
</pre>
<pre class=ans>
fetch('/worldl.json')
  .then((r)=>r.json())
  .then((r)=>{
    document.body.innerHTML =
      r.filter(r=>r.continent === 'Europe')
         .map(r=>`<div>${r.name}</div>`)
         .map(r=>`<div>${r.name}</div>`)
         .join('');
         .join('');

Revision as of 16:32, 17 January 2022




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 https://progzoo.net/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.innerHTML = 
       `<div>${tgt.name}</div>`;
     });
fetch('/worldl.json')
  .then((r)=>r.json())
  .then((r)=>{
     let tgt = r[102];
     document.body.innerHTML =
       `<div>${tgt.name}, ${tgt.population}</div>`;
  });

Include image

Include three div elements and an img for country 151. Use style='width:100px;' for the img
fetch('/worldl.json')
  .then((r)=>r.json())
  .then((r)=>{
     let tgt = r[151];
     document.body.innerHTML = 
       `<div>${tgt.name}, ${tgt.capital}</div>`;
     });
fetch('/worldl.json')
  .then((r)=>r.json())
  .then((r)=>{
     let tgt = r[151];
     document.body.innerHTML = `
<div>Name: ${tgt.name}</div>
<div>Capital: ${tgt.capital}</div>
<div>Population: ${tgt.population}</div>
<img src='${tgt.flag}' style='width:100px'/>
`;
     });


Output in a table

fetch('/worldl.json')
  .then((r)=>r.json())
  .then((r)=>{
     let tgt = r[172];
     document.body.innerHTML = 
       `<div>${tgt.name}, ${tgt.capital}</div>`;
     });
fetch('/worldl.json')
  .then((r)=>r.json())
  .then((r)=>{
     let tgt = r[172];
     document.body.innerHTML = `
<table>
<tr><th>Name</th><td>${tgt.name}</td</tr>
<tr><th>Continent</th><td>${tgt.continent}</td</tr>
<tr><th>Capital</th><td>${tgt.capital}</td</tr>
<tr><th>Population</th><td>${tgt.population}</td</tr>
</table>
`;
     });


Format numbers

For country 184. Use .toLocaleString() to format numbers better. Show the GDP in billions, include $ symbol as GDP is given in US dollars
fetch('/worldl.json')
  .then((r)=>r.json())
  .then((r)=>{
     let tgt = r[184];
     document.body.innerHTML = 
       `<div>${tgt.population.toLocaleString()}</div>`;
     });
fetch('/worldl.json')
  .then((r)=>r.json())
  .then((r)=>{
     let tgt = r[184];
     document.body.innerHTML =        `
<table>
<tr><th>Name</th><td>${tgt.name}</td></tr>
<tr><th>Continent</th><td>${tgt.continent}</td></tr>
<tr><th>Capital</th><td>${tgt.capital}</td></tr>
<tr><th>Population</th><td>${tgt.population.toLocaleString('en')}</td></tr>
<tr><th>GDP</th><td>$${(tgt.gdp/1e9).toLocaleString('en')} billion</td></tr>
</table>
`;
     });


Working with lists

In the following questions you must look at the list of the countries to work out the answer.

Biggest Country in the World

Show the name of the country with the largest population.
fetch('/worldl.json')
  .then((r)=>r.json())
  .then((r)=>{
     let biggest = 0;
     for(let i = 0; i<r.length; i++){
       if (r[i].area > r[biggest].area){
         biggest = i;
       }
     }
     document.body.innerHTML = 
       `<div>${r[biggest].name}</div>`;
   });
fetch('/worldl.json')
  .then((r)=>r.json())
  .then((r)=>{
     let biggest = 0;
     for(let i = 0; i<r.length; i++){
       if (r[i].population > r[biggest].population){
         biggest = i;
       }
     }
     document.body.innerHTML = 
       `<div>${r[biggest].name}</div>`;
   });

Total population

Show the total population of the world.

fetch('/worldl.json')
  .then((r)=>r.json())
  .then((r)=>{
     let acc = 0;
     for(let i = 0; i<r.length; i++){
       acc += r[i].population
     }
     document.body.innerHTML = 
       `<div>${acc}</div>`;
   });

Countries bigger than 1000000

Show list of countries with an area of more than 1 million square kilometers.

fetch('/worldl.json')
  .then((r)=>r.json())
  .then((r)=>{
     document.body.innerHTML =
       r.filter(r=>r.area>1000000)
        .map(r=>`<div>${r.name}</div>`)
        .join('');
   });

Countries in Europe

Show list of countries where the continent is Europe.

fetch('/worldl.json')
  .then((r)=>r.json())
  .then((r)=>{
     document.body.innerHTML =
       r.filter(r=>r.continent === 'Europe')
        .map(r=>`<div>${r.name}</div>`)
        .join('');
   });