티스토리 뷰

카테고리 없음

reactJS - 영화 웹 서비스 만들기(2)

코딩하는 둥아 2021. 4. 11. 01:53
728x90

javascript map exercise

example1

friends = ["dal", "mark", "lynn", "japan guy"]

friends.map(current => {
  console.log(current);
  return 0
})

output :

각 element가 console에 찍히고,

[0,0,0,0]이 리턴됨

 

example2

friends = ["dal", "mark", "lynn", "japan guy"]

friends.map(function(friend){
  return friend+" heart";
})

각 item에 function을 적용하고 array를 반환함

 

 

example3

import React from 'react';

function Food({ name , picture}) {
  return <div>
    <h2>I like {name}</h2>
    <img src={picture}></img>
  </div>

}

const foodILike = [
  {
    name: "Kimchi",
    image: "https://cdn.crowdpic.net/detail-thumb/thumb_d_CDC14868821FF3F20C77BC8BC15E6355.jpg"
  },
  {
    name: "삼겹살",
    image: "https://www.google.com/url?sa=i&url=https%3A%2F%2Fwoman.chosun.com%2Fmobile%2Fnews%2Fview.asp%3Fcate%3DC05%26mcate%3DM1001%26nNewsNumb%3D20200868344&psig=AOvVaw1PDIe_YRZfYP376cyl9Jaw&ust=1618127180459000&source=images&cd=vfe&ved=0CAIQjRxqFwoTCKjw0tCX8-8CFQAAAAAdAAAAABAD"
  },
  {
    name: "비빔밥",
    image: "https://lh3.googleusercontent.com/proxy/3yVmq_QLhpBBbTkZ1G65O25BVAF03Ebru9Dub6aYfPCeCcXxua8uMV6pVPv20tpXmKu8vLcvk1EsIFYAMrE98LSObZvE2BKjkmM"
  },
  {
    name: "Kimchi",
    image: "https://cdn.crowdpic.net/detail-thumb/thumb_d_CDC14868821FF3F20C77BC8BC15E6355.jpg"
  },
  {
    name: "삼겹살",
    image: "https://www.google.com/url?sa=i&url=https%3A%2F%2Fwoman.chosun.com%2Fmobile%2Fnews%2Fview.asp%3Fcate%3DC05%26mcate%3DM1001%26nNewsNumb%3D20200868344&psig=AOvVaw1PDIe_YRZfYP376cyl9Jaw&ust=1618127180459000&source=images&cd=vfe&ved=0CAIQjRxqFwoTCKjw0tCX8-8CFQAAAAAdAAAAABAD"
  },
  {
    name: "비빔밥",
    image: "https://lh3.googleusercontent.com/proxy/3yVmq_QLhpBBbTkZ1G65O25BVAF03Ebru9Dub6aYfPCeCcXxua8uMV6pVPv20tpXmKu8vLcvk1EsIFYAMrE98LSObZvE2BKjkmM"
  }
];


function App() {
  return (
    <div className="App">
      {foodILike.map(dish => <Food name={dish.name} picture={dish.image}/>)}
    </div>
  );
}

export default App;

output

object list에 담긴 객체를 map을 사용해서 Food component로 효율적이게 나타낼 수 있음

food component에 kimchi라는 value로 prop name을 전달

jsx + props 로 component 재사용 가능!!

jsx = html + javascript

 

 

renderFood 라는 새로운 function을 사용한 방법

function renderFood(dish) {
  return <Food name={dish.name} picture={dish.image}/>
}

function App() {
  return (
    <div className="App">
      {console.log(foodILike.map(renderFood))}
      {foodILike.map(renderFood)}
      {/* {foodILike.map(dish => <Food name={dish.name} picture={dish.image}/>)} */}
    </div>
  );
}

react의 모든 component들은 unique key를 가져야함.

 

전체 food example

//https://nomadcoders.co/react-fundamentals/lobby
// #3 STATE 할 차례!

import React from 'react';
import PropTypes from "prop-types";

function Food({ name , picture, rating}) {
  return <div>
    <h2>I like {name}</h2>
    <h4>{rating} / 5.0</h4>
    <img src={picture} alt={name}></img>
  </div>
}

Food.propTypes = {
  name: PropTypes.string.isRequired,
  picture: PropTypes.string.isRequired,
  rating: PropTypes.number.isRequired,
}
// required, type check를 할 수 있음!!

const foodILike = [
  {
    id:1,
    name: "Kimchi",
    image: "https://cdn.crowdpic.net/detail-thumb/thumb_d_CDC14868821FF3F20C77BC8BC15E6355.jpg",
    rating: 4.7
  },
  { 
    id:2,
    name: "삼겹살",
    image: "https://www.google.com/url?sa=i&url=https%3A%2F%2Fwoman.chosun.com%2Fmobile%2Fnews%2Fview.asp%3Fcate%3DC05%26mcate%3DM1001%26nNewsNumb%3D20200868344&psig=AOvVaw1PDIe_YRZfYP376cyl9Jaw&ust=1618127180459000&source=images&cd=vfe&ved=0CAIQjRxqFwoTCKjw0tCX8-8CFQAAAAAdAAAAABAD",
    rating: 4.0
  },
  {
    id:3,
    name: "비빔밥", 
    image: "https://lh3.googleusercontent.com/proxy/3yVmq_QLhpBBbTkZ1G65O25BVAF03Ebru9Dub6aYfPCeCcXxua8uMV6pVPv20tpXmKu8vLcvk1EsIFYAMrE98LSObZvE2BKjkmM",
    rating: 3.2
  },
  {
    id:4,
    name: "Kimchi",
    image: "https://cdn.crowdpic.net/detail-thumb/thumb_d_CDC14868821FF3F20C77BC8BC15E6355.jpg",
    rating: 2.7
  },
  {
    id:5,
    name: "삼겹살",
    image: "https://www.google.com/url?sa=i&url=https%3A%2F%2Fwoman.chosun.com%2Fmobile%2Fnews%2Fview.asp%3Fcate%3DC05%26mcate%3DM1001%26nNewsNumb%3D20200868344&psig=AOvVaw1PDIe_YRZfYP376cyl9Jaw&ust=1618127180459000&source=images&cd=vfe&ved=0CAIQjRxqFwoTCKjw0tCX8-8CFQAAAAAdAAAAABAD",
    rating: 4.8
  },
  {
    id:6,
    name: "비빔밥",
    image: "https://lh3.googleusercontent.com/proxy/3yVmq_QLhpBBbTkZ1G65O25BVAF03Ebru9Dub6aYfPCeCcXxua8uMV6pVPv20tpXmKu8vLcvk1EsIFYAMrE98LSObZvE2BKjkmM",
    rating: 3.1
  }
];

function renderFood(dish) {
  return <Food name={dish.name} picture={dish.image}/>
}

function App() {
  return (
    <div className="App">
      {/* {console.log(foodILike.map(renderFood))}
      {foodILike.map(renderFood)} */}
      {foodILike.map(dish => 
      <Food 
        key={dish.id} 
        name={dish.name} 
        picture={dish.image}
        rating={dish.rating}/>)}
    </div>
  );
}

export default App;

 

 

728x90
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/01   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
글 보관함