Hello everyone, I’m in a bit of a pickle. I started learning how to program not too long ago and I am trying to build a meal finder app with React. I get typeError meals.map is not a function if I try mapping through meals. I then tried using Object.keys to be able to use map but then nothing renders except a unique item. The API structure really messes up with my head it looks like this:
[https://www.themealdb.com/api/json/v1/1/search.php?s=Arrabiata](http://Api json)
This is an object with a nested array of objects inside. How do you map through this ?
As I said I used Object.keys and at least it logs results in the console but nothing renders. When I search something: I see a unique item with nothing in it. No title, no image. In the console when I inspect the app I read {meals: Array(8)} and “Warning: Each child in a list should have a unique “key” prop.” I thought did write a unique key: key={meal.idMeal}.
Thank you a lot if you can help
Here is my code, in my app component:
import React, { useState } from 'react';
import './App.css';
import Search from './components/Search';
import Meals from './components/Meals';
import axios from 'axios';
function App() {
const [meals, setMeals] = useState({});
const searchMeals = async meals => {
const res = await axios.get(
`https://www.themealdb.com/api/json/v1/1/search.php?s=${meals}`
);
console.log(res.data);
setMeals({ meals: res.data });
};
return (
<div className='App'>
<Search searchMeals={searchMeals}></Search>
<Meals searchMeals={searchMeals} meals={meals}></Meals>
</div>
);
}
export default App;
I created a component Meals with this inside:
import React from 'react'
import MealsItem from './MealsItem'
const Meals = ({ meals}) => {
return (
<div >
{Object.keys(meals).map(meal=>(
<MealsItem key={meal.idMeal} meal={meal}/>
))}
</div>
);
};
export default Meals
and then for the rendering part I created a MealsItems component:
import React, { Fragment } from 'react';
const MealsItem = ({ meal :{strMealThumb, strMeal,}}) => {
return (
<Fragment>
<div id='result-heading'>
<h2>Search result for: {strMeal}</h2>
</div>
<div className='meal'>
<img src={strMealThumb} alt={strMeal} />
<div className='meal-info'>
<h3>{strMeal}</h3>
</div>
</div>
</Fragment>
);
};
export default MealsItem;