React recipe search App
Recently I am trying to find some React app to practice. All kinds of API make us easier to fetch data. I am using the API called EDAMAM. It upgraded to V2 .
- set up the react app
npx create-react-app <app-name>
2.App.js
data:image/s3,"s3://crabby-images/f0800/f08008166af74816a949ca15d3d06e9fdb13b7c8" alt=""
search-form includes input text and a button.
when the input text is changing, the search value should change in State.
when clicking the button, the final search state is done, and it becomes query state .
data:image/s3,"s3://crabby-images/332ba/332ba2320f6fc36c7d971eac1670d3386c5253de" alt=""
data:image/s3,"s3://crabby-images/ea624/ea6246c33c0867b07fa8bc35addadcfe66d35903" alt=""
To manipulate the data, you need to fetch the data from API.
data:image/s3,"s3://crabby-images/ebbac/ebbac3815bb858472cd1cc9b7fb608eaad902b65" alt=""
For the API URL document
using async and await to get data.
Sign up for the account for the private API key, it’s free.
`https://api.edamam.com/api/recipes/v2?type=public&q=${query}&app_id=${APP_ID}&app_key=${APP_KEY}&random=true`
When you console.log() the data,showing below:
data:image/s3,"s3://crabby-images/56a26/56a266e4accdd2a835a0a0bff6a754b8d9ba240c" alt=""
so the resource you need for recipes are data.hits
with useEffect() to run the API when query changing,meaning when click the button.
data:image/s3,"s3://crabby-images/e94a8/e94a8f86de185299799be94a9d356814722dede7" alt=""
3. The individual recipe is a component.
data:image/s3,"s3://crabby-images/1a33e/1a33e40e494af34dab26b6a63db4b3b0189bbf41" alt=""
4. Styling the components
For one component style,using {style.className}. Build the file recipe.module.css
data:image/s3,"s3://crabby-images/f71df/f71df50f1bc428d2f24cb1ee79b5d2564c2cded5" alt=""
Giving some styles.and import it in Recipe.js
App.css
data:image/s3,"s3://crabby-images/118a9/118a9bcb40027422d6da12700be224ec2718c48b" alt=""
data:image/s3,"s3://crabby-images/70631/70631621eece30574ae4a3f2225fe9d148754678" alt=""
I didn’t put time on CSS. There is more space for improving it though.😊