data:image/s3,"s3://crabby-images/20360/20360b902657aebfce4fd8fab5b4da74a22aa74c" alt="React.JS) 6. 간단한 Coin Tracker 만들기"
1. Coin Tracker
- 암호화폐 가격을 추적하고 관리하는 애플리케이션이나 웹사이트
- 자신의 포트폴리오를 관리하고, 가격 변동을 확인하고, 트렌드를 분석할 수 있음
2. 간단한 Coin Tracker 만들기
- 단순히 암호화폐들과 가격을 나열
- useEffect를 이용ㅠ ㅜㅜ
- 페이지나 앱에 들어왔을 때 로딩 메세지가 표시
- 코인들이 나열되면 로딩 메세지를 숨기고 리스트로 표시
3. 초기 상태
import { useState } from "react"; function App() { return ( <div> </div> ); } export default App;
3. Coin 데이터 가져오기
- 로딩 화면 만들기
import { useState } from "react"; function App() { const [loading, setLoading] = useState(true); return ( <div> <h1>The Coins</h1> {loading ? <strong>Loading ...</strong> : null} </div> ); } export default App;
data:image/s3,"s3://crabby-images/be49d/be49d7475da332a9c153b323535d6085bd875329" alt="notion image"
- api 요청해서 데이터 받아오기
https://api.coinpaprika.com/v1/tickers
data:image/s3,"s3://crabby-images/81ec0/81ec091efd7d966eed96a7729cb2485ab1bdea19" alt="notion image"
import { useEffect, useState } from "react"; function App() { const [loading, setLoading] = useState(true); useEffect(() => { fetch("https://api.coinpaprika.com/v1/tickers"); }, []) return ( <div> <h1>The Coins</h1> {loading ? <strong>Loading ...</strong> : null} </div> ); } export default App;
data:image/s3,"s3://crabby-images/235c5/235c50e32250d024f1c9af73a3e927194c3175db" alt="notion image"
data:image/s3,"s3://crabby-images/6768a/6768ace889a26c14b3902ae39bc6653786dcb805" alt="notion image"
- 가져온 데이터를 json으로 만들어서 콘솔에 표시하기
import { useEffect, useState } from "react"; function App() { const [loading, setLoading] = useState(true); useEffect(() => { fetch("https://api.coinpaprika.com/v1/tickers") .then(response => response.json()) .then((json) => console.log(json)); }, []); return ( <div> <h1>The Coins</h1> {loading ? <strong>Loading ...</strong> : null} </div> ); } export default App;
data:image/s3,"s3://crabby-images/a3c74/a3c74004476bfca83b72eb7d313d12b02c2f892c" alt="notion image"
5. 데이터를 화면에 표시하기
- 가져온 데이터를 state에 넣기
import { useEffect, useState } from "react"; function App() { const [loading, setLoading] = useState(true); const [coins, setCoins] = useState([]); useEffect(() => { fetch("https://api.coinpaprika.com/v1/tickers") .then(response => response.json()) .then((json) => setCoins(json)); setLoading(false); }, []); return ( <div> <h1>The Coins</h1> {loading ? <strong>Loading ...</strong> : null} </div> ); } export default App;
data:image/s3,"s3://crabby-images/95569/95569c64336423fe5cadfc3a2f66059d7b0a3d3d" alt="notion image"
- map을 이용하여 coins 배열 안에 있는 coin들 표시하기
data:image/s3,"s3://crabby-images/1a222/1a22277d22b1fc7789a23af97f4fcec52effabd4" alt="notion image"
import { useEffect, useState } from "react"; function App() { const [loading, setLoading] = useState(true); const [coins, setCoins] = useState([]); useEffect(() => { fetch("https://api.coinpaprika.com/v1/tickers") .then((response) => response.json()) .then((json) => { setCoins(json); setLoading(false); }); }, []); return ( <div> <h1>The Coins</h1> {loading ? <strong>Loading ...</strong> : null} <ul> {coins.map((coin) => ( <li key={coin.id}>{coin.name} ({coin.symbol}): {coin.quotes.USD.price} USD</li> ))} </ul> </div> ); } export default App;
data:image/s3,"s3://crabby-images/0175a/0175a6ec2f5079f595a596a19385e4d2f3e88bb7" alt="notion image"
6. 마무리하기
import { useEffect, useState } from "react"; function App() { const [loading, setLoading] = useState(true); const [coins, setCoins] = useState([]); useEffect(() => { fetch("https://api.coinpaprika.com/v1/tickers") .then((response) => response.json()) .then((json) => { setCoins(json); setLoading(false); }); }, []); return ( <div> <h1>The Coins({coins.length})</h1> {loading ? <strong>Loading ...</strong> : null} <ul> {coins.map((coin) => ( <li key={coin.id}>{coin.name} ({coin.symbol}): {coin.quotes.USD.price} USD</li> ))} </ul> </div> ); } export default App;
data:image/s3,"s3://crabby-images/d1985/d1985a20eadfb3e53d675f99fad1bc3cc2f0c6ae" alt="notion image"
data:image/s3,"s3://crabby-images/39156/391562646a5ca4518b168daf8a5bda78539b9bb1" alt="notion image"
Share article