인프런 커뮤니티 질문&답변
3. 동물 앨범 만들기-2-3 질문입니다.
해결된 질문
작성
·
56
1
let temp = [];
if (this.state) {
this.state.forEach((elm) => {
temp += `<img .../>`
});
}temp는 배열인데 배열에 += 로 작업하신 이유가 있나요?
temp = ''; 가 아닌 [] 로 시작한 이유가 궁금합니다.
답변 2
0
안녕하세요 테라님 🙂 질문 감사합니다.
해당 코드는 '동물앨범 1-1' 강의 영상 및 핸드북에 '빈 문자열로 초기화 해주세요'라고 적어두었습니다. 강의 수강에 불편을 드려 죄송합니다 🙇🏻♀️
https://inf.run/7hfCg
해당 질문 참고하시면 좋을 것 같습니다!! 동물앨범 2-3영상도 수정해두었습니다. 감사합니다 🙂
0
안녕하세요, 인프런 AI 인턴입니다. 테라님, 질문 주셔서 감사합니다.
질문하신 코드는 JavaScript에서 문자열이나 배열을 다루는 방법에 대한 혼동을 줄 수 있는 부분인데요, temp를 초기화할 때 배열([])로 하셨다면, 배열에 문자열을 추가하는 방식 대신 배열 메서드인 push()를 사용하는 것이 좋습니다. 그러나 이후 문자열 연결 방식으로 코드를 작성하신 것이라면, temp = '';로 문자열로 초기화하고 += 연산자를 사용하는 것이 자연스러울 것입니다.
배열과 문자열의 차이:
배열(
[])을 초기화하고 사용하는 경우:- 배열에 요소를 추가할 때는
push()메서드를 사용합니다.
temp.push();이런 식으로 추가할 수 있습니다.
- 배열에 요소를 추가할 때는
문자열(
'')을 초기화하고 사용하는 경우:- 문자열로 요소를 추가할 때는
+=연산자를 사용하여 문자열을 합치게 됩니다.
temp +=;이렇게 요소를 추가합니다.
- 문자열로 요소를 추가할 때는
왜 배열로 선언했는지:
배열로 선언하는 경우:
- 여러 HTML 태그를 준비하고 나중에 한꺼번에 하나의 문자열로 결합할 수 있기 때문에 추가적인 활용이 가능합니다. 최종적으로
innerHTML등에 삽입할 때는join()메서드를 사용하여 문자열로 변환할 수 있습니다.
- 여러 HTML 태그를 준비하고 나중에 한꺼번에 하나의 문자열로 결합할 수 있기 때문에 추가적인 활용이 가능합니다. 최종적으로
문자열로 선언하는 경우:
- 단순히 문자열을 하나씩 결합하여 사용할 경우에 적합합니다.
- 단순히 문자열을 하나씩 결합하여 사용할 경우에 적합합니다.
이 부분에 대한 더 많은 정보를 찾고자 하신다면, 이전 질문에서 비슷한 논의가 있었으니 참고하시길 바랍니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.





