• Empleos
  • Sobre nosotros
  • profesionales
    • Inicio
    • Empleos
    • Cursos y retos
  • empresas
    • Inicio
    • Publicar vacante
    • Nuestro proceso
    • Precios
    • Evaluaciones
    • Nómina
    • Blog
    • Comercial
    • Calculadora de salario

0

163
Vistas
Mi código Javascript JSON en la página HTML no representa los objetos de la matriz RESTful API, aunque obtengo los datos de la API. ¿Qué tengo que hacer?

ingrese la descripción de la imagen aquí El problema es que los objetos de la API no se están procesando en HTML, ¿qué hice mal?

 <button onclick = "showCountries()">Show Countries</button> <div id = "feed"></div> <script> function showCountries(){ let xhr = new XMLHttpRequest() xhr.open('GET', 'https://restcountries.com/v3.1/all', true) xhr.onload = function(){ if(xhr.status == 200){ console.log('success') let countries = JSON.parse(this.response) countries.forEach(country=>{ const countryCard = document.createElement('div') const countryCardImage = document.createElement('img') countryCard.innerHTML = country.name countryCardImage.src = country.flag document.getElementById('feed').appendChild(countryCard) }) } } xhr.send() } </script>
about 3 years ago · Juan Pablo Isaza
2 Respuestas
Responde la pregunta

0

Finalmente descubrí cómo mostrar banderas, aquí está la fuente:

 function showCountries(){ let xhr = new XMLHttpRequest() xhr.open('GET', 'https://restcountries.com/v3.1/all', true) xhr.onload = function(){ if(xhr.status == 200){ console.log('success') let countries = JSON.parse(this.response) countries.forEach(country=>{ const countryCard = document.createElement('div') const countryCardImage = document.createElement('div')// must be div to display small image countryCard.innerHTML = country.name.common countryCardImage.innerHTML = country.flag console.log(country.flag) document.getElementById('feed').appendChild(countryCard) document.getElementById('feed').appendChild(countryCardImage) //this is it! }) } }
about 3 years ago · Juan Pablo Isaza Denunciar

0

Porque country.name es un objeto. Debe usar una cadena para establecer el HTML interno del elemento. De acuerdo con la estructura de datos de su respuesta, puede usarlo así:

 function showCountries() { let xhr = new XMLHttpRequest() xhr.open('GET', 'https://restcountries.com/v3.1/all', true) xhr.onload = function() { if (xhr.status == 200) { console.log('success') let countries = JSON.parse(this.response) countries.forEach(country => { const countryCard = document.createElement('div') const countryCardImage = document.createElement('img') countryCard.innerHTML = country.name.common countryCardImage.src = country.flags.png countryCardImage.style.width = "30px" countryCard.append(countryCardImage) document.getElementById('feed').appendChild(countryCard) }) } } xhr.send() }
 <button onclick="showCountries()">Show Countries</button> <div id="feed"></div>

about 3 years ago · Juan Pablo Isaza Denunciar
Responde la pregunta
Encuentra empleos remotos

¡Descubre la nueva forma de encontrar empleo!

Top de empleos
Top categorías de empleo
Empresas
Publicar vacante Precios Nuestro proceso Comercial
Legal
Términos y condiciones Política de privacidad
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recomiéndame algunas ofertas
Necesito ayuda