3. 동물 앨범 만들기-2-3 질문입니다.
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 태그를 준비하고 나중에 한꺼번에 하나의 문자열로 결합할 수 있기 때문에 추가적인 활용이 가능합니다. 최종적으로
문자열로 선언하는 경우:
- 단순히 문자열을 하나씩 결합하여 사용할 경우에 적합합니다.
- 단순히 문자열을 하나씩 결합하여 사용할 경우에 적합합니다.
이 부분에 대한 더 많은 정보를 찾고자 하신다면, 이전 질문에서 비슷한 논의가 있었으니 참고하시길 바랍니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
콜백 함수 메서드 등록
0
82
2
ssr방식 경험
0
75
1
compare 함수 설명에 오해의 소지가 있어보입니다.
0
82
2
API를 비동기 처리하는 이유가 끊겨서 그런건가요?
0
96
2
DOM 트리 보는 곳
0
80
1
배열과 객체의 구조분해할당 방법이 다른 이유
0
82
2
배열 메서드가 순수 함수인지 확인하는 방법
0
72
2
콜백 함수의 매개변수로 _를 쓰는 이유가 무엇인가요?
0
71
2
콜백 함수의 매개변수는 어떻게 구분되나요?
0
58
1
호이스팅 안쓰는게 좋나요?
0
54
2
함수 선언식과 함수 표현식은 어떤 경우에 쓰면 좋나요?
0
82
2
?. 연산자는 자바스크립트 연산자인가요?
0
46
1
JS의 논리 연산자 &&, ||가 리액트의 조건부 렌더링 &&, ||인가요?
0
82
2
자바스크립트 질문
1
103
2
동물앨범만들기 1-1 api 오류
0
54
2
CityList개발-handleLoadMore함수질문
0
69
1
객체와 배열의 const 차이
0
46
1
const 객체/배열 차이
0
63
2
header 개발 새로고침 오류
0
67
2
Promise 객체
1
58
2
cityList 렌더가 안되는 문제
0
53
2
init 함수 앞에 await
1
66
2
동물 앨범 만들기 pushtState 관련
0
60
2
동물 앨범 만들기 사진 관련 문의
0
75
2





