강의

멘토링

로드맵

Inflearn brand logo image

인프런 커뮤니티 질문&답변

테라님의 프로필 이미지
테라

작성한 질문수

한 번에 끝내는 자바스크립트: 바닐라 자바스크립트로 SPA 개발까지

동물 앨범 만들기-2-3

3. 동물 앨범 만들기-2-3 질문입니다.

해결된 질문

작성

·

48

1

let temp = [];

if (this.state) {
    this.state.forEach((elm) => {
       temp += `<img .../>` 
    });
}

temp는 배열인데 배열에 += 로 작업하신 이유가 있나요?

 

temp = ''; 가 아닌 [] 로 시작한 이유가 궁금합니다.

답변 2

0

효빈 Hyobin님의 프로필 이미지
효빈 Hyobin
지식공유자

안녕하세요 테라님 🙂 질문 감사합니다.

해당 코드는 '동물앨범 1-1' 강의 영상 및 핸드북에 '빈 문자열로 초기화 해주세요'라고 적어두었습니다. 강의 수강에 불편을 드려 죄송합니다 🙇🏻‍♀️
https://inf.run/7hfCg
해당 질문 참고하시면 좋을 것 같습니다!! 동물앨범 2-3영상도 수정해두었습니다. 감사합니다 🙂

0

안녕하세요, 인프런 AI 인턴입니다. 테라님, 질문 주셔서 감사합니다.

질문하신 코드는 JavaScript에서 문자열이나 배열을 다루는 방법에 대한 혼동을 줄 수 있는 부분인데요, temp를 초기화할 때 배열([])로 하셨다면, 배열에 문자열을 추가하는 방식 대신 배열 메서드인 push()를 사용하는 것이 좋습니다. 그러나 이후 문자열 연결 방식으로 코드를 작성하신 것이라면, temp = '';로 문자열로 초기화하고 += 연산자를 사용하는 것이 자연스러울 것입니다.

배열과 문자열의 차이:

  1. 배열([])을 초기화하고 사용하는 경우:

    • 배열에 요소를 추가할 때는 push() 메서드를 사용합니다.
    • temp.push(); 이런 식으로 추가할 수 있습니다.
  2. 문자열('')을 초기화하고 사용하는 경우:

    • 문자열로 요소를 추가할 때는 += 연산자를 사용하여 문자열을 합치게 됩니다.
    • temp +=; 이렇게 요소를 추가합니다.

왜 배열로 선언했는지:

  • 배열로 선언하는 경우:

    • 여러 HTML 태그를 준비하고 나중에 한꺼번에 하나의 문자열로 결합할 수 있기 때문에 추가적인 활용이 가능합니다. 최종적으로 innerHTML 등에 삽입할 때는 join() 메서드를 사용하여 문자열로 변환할 수 있습니다.
  • 문자열로 선언하는 경우:

    • 단순히 문자열을 하나씩 결합하여 사용할 경우에 적합합니다.

이 부분에 대한 더 많은 정보를 찾고자 하신다면, 이전 질문에서 비슷한 논의가 있었으니 참고하시길 바랍니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

테라님의 프로필 이미지
테라

작성한 질문수

질문하기