1. unique "key" prop 해결하기
어제부터 말썽인 에러 오늘은 꼭 해결하고 말테다
니가 이기나 내가 이기나 해보자 라는 마인드로 모든 요소에 key를 넣어줬다
return (
<>
<StTitle key={"stTitleKey"}>
<h2>나만의 포켓몬</h2>
<StDiv key={"myPokemonsStDiv"}>
{myPokemons.map((pokemon) => {
// 몬스터볼임
if (isUUID(pokemon.id)) {
return (
<div key={pokemon.id}>
<StPokemonBalImg
key={`${pokemon.id}-img`}
src=""
/>
</div>
);
}
const key = `my-${pokemon.id}`;
return (
<>
<StCard key={key}>
<img
src={pokemon.img_url}
onClick={() => navigateToDetail(pokemon.id)}
key={`myImg-${pokemon.id}`}
/>
<div key={`name-${pokemon.id}`} onClick={() => navigateToDetail(pokemon.id)}>
{pokemon.korean_name}{" "}
</div>
<StAddAndDeleteButton
key={`btn-${pokemon.id}`}
onClick={() => {
removeMyPokemon(pokemon.id);
}}
>
삭제
</StAddAndDeleteButton>
</StCard>
</>
);
})}
</StDiv>
</StTitle>
</>
그리고 여전한 에러,,,,,여전히 30번째에서 난다

결국 튜터님을 찾아가 살려주세요 했다
key는 최상단 요소에만 있으면 되니 다른건 다 지우자고 하셨다
불필요한 key들을 다 지우고 나니 문제점이 보였다
위의 코드블럭에서 알 수 있듯이 이 맵에는 리턴이 두번 있는데, 두번째에 있는 리턴 제일 상단에 <>가 들어있었던 것!!!

아마 처음에 코드를 작성 할 때 넣어놓고 지우는걸 깜박했던 것 같다
저 부분에 키가 없어서 에러가 나는거였다
이제 필요없으니까 지워주니 더이상 에러가 나지 않았다,,,!!!!
그럼 왜 30번째에서 계속 에러 메시지가 뜨는거냐고 여쭤보니
그게 맵의 시작부분이라서 그렇다고 하셨다
에러 메시지가 세세하게 알려주지는 않는 것 같다고 느꼈다
의심했던 key에 대한 나의 지식?이 틀리지 않았다
맵을 돌릴 때 컨텍스트 최상단에만 키를 넣어주면 된다!!!
2. hover (feat.transform)
카드 위에 커서가 올라가면 카드가 올라오는 느낌을 주고 싶었고, 버튼 위에 올리면 색이 변하는 그런걸 하고 싶었다
그게 hover를 쓰면 되는건 알았다
하지만! 어떻게 쓰는지는 몰랐다
일단 hover는 이해하기 쉬웠다 위에 올라가면!이니까 마치 if(when cursor is on the button){}같은 느낌이랄까
찾아보니 css의 transform을 사용하면 회전, 크기 조절, 기울이기, 이동의 효과를 줄 수 있다고 한다
https://developer.mozilla.org/ko/docs/Web/CSS/transform
transform - CSS: Cascading Style Sheets | MDN
CSS transform 속성으로 요소에 회전, 크기 조절, 기울이기, 이동 효과를 부여할 수 있습니다. transform은 CSS 시각적 서식 모델의 좌표 공간을 변경합니다.
developer.mozilla.org
translateY()에 -값을 주면 위로 올라가는 효과를 줄 수 있다
https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/translateY
translateY() - CSS: Cascading Style Sheets | MDN
The translateY() CSS function repositions an element vertically on the 2D plane. Its result is a <transform-function> data type.
developer.mozilla.org
또한, scale()에 +값을 주면 요소가 커진다
https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/scale
scale() - CSS: Cascading Style Sheets | MDN
The scale() CSS function defines a transformation that resizes an element on the 2D plane. Because the amount of scaling is defined by a vector [sx, sy], it can resize the horizontal and vertical dimensions at different scales. Its result is a <transform-f
developer.mozilla.org
둘을 합치면 카드 위에 커서를 올렸을 때 카드가 올라오면서 조금 커지는 효과를 줄 수 있다
이 모든걸 합쳐서 StCard 안에 넣어주면 완성!

3. media query
카드 리스트는 반응형으로 잘 나오는데 덱스는 되지 않아 씨름하던 중 튜터님을 찾아갔다
미디어쿼리를 공부해보라고 하셨다
처음들어봐서 조금 겁먹었는데 별거 아니었다(ㅋㅋ)
위의 hover랑 비슷한 느낌이다 근데 이제 조건문을 내가 넣을 수 있는!
@media(){}이렇게 쓰고 ()안에 조건을 넣으면 된다
나의 조건은 카드를 flex-wrap으로 감싸주고 gap을 줄여주는 것!
반응형으로 잘 나오는걸 볼 수 있다! 성공!


새로운 css 속성들을 배우게 되어 어렵지만 신기하고 재밌었다
내일부터는 리덕스툴킷으로 리팩토링 도전!
'2024내일배움캠프 > 포켓몬 도감_개발_트러블슈팅' 카테고리의 다른 글
[TIL_포켓몬 도감_트러블슈팅(5)] 2/11 vercel로 배포! (1) | 2025.02.11 |
---|---|
[TIL_포켓몬 도감_트러블슈팅(5)] 2/10 Redux TLK로 리팩토링하기 (0) | 2025.02.10 |
[TIL_포켓몬 도감_트러블슈팅(3)] 2/5 useContext로 리팩토링하기 (0) | 2025.02.05 |
[TIL_포켓몬 도감_트러블슈팅(2)] 2/4 (0) | 2025.02.04 |
[TIL_포켓몬 도감_트러블슈팅(1)] 2/3 (0) | 2025.02.03 |