개인공부
JavaScript push를 이용해서 렌더링하기.
하이후에호
2021. 6. 9. 22:22
반응형
<ul>
<li><a href="#">API 1</a><li>
<li><a href="#">API 2</a><li>
<li><a href="#">API 3</a><li>
<li><a href="#">API 4</a><li>
</ul>
특정 API 호출시 API 1 ~ API 4 까지를 반환하고 이값을 ul > li > a 로 렌더링 할려고한다.
React를 사용할 수도 있지만 JavaScript만으로 구현을 한다고하면 대부분은 아래와 같은 과정을 지나갑니다.
const ul = documnet.createElement('ul');
// API 호출함수 ["API 1", "API 2", "API 3", "API 4"] 반환
const API = getAPI(URL);
for(let i =0; i< 4; i++) {
const li = document.createElement('li');
const a = document.createElemen('a');
a.href = `#${API[i]}`;
li.appendChild(a);
ul.appendChild(li);
}
document.getElementById('root').appendChild(ul);
물론 위와 같은 방법도 사용하지만 이번에는 push 함수와 innerHTML로 작성해보자.
const list = []; javaScript에서는 배열을 나타낸다. 이때 list 내장함수로 push가 있는데 LinkedList 성질처럼 뒤쪽으로 FIFO형태로 적재된다.
const ul = documnet.createElement('ul');
// API 호출함수 ["API 1", "API 2", "API 3", "API 4"] 반환
const API = getAPI(URL);
const list = [];
list.push('<ul>');
for(let i =0; i< 4; i++) {
newsList.push(`
<li>
<a href="#${API[i]}")</a>
</li>
`);
}
list.push('</ul>');
document.getElementById('root').innerHTML = list.join('');
이런식으로 push를 이용하고 innerHTML과 join을 이용해서 코드를 바꿀수 있다.
join 같은 경우는 파라미터를 넣지않으면 배열들을 ',' 로 합쳐서 보여주고 파라미터가 들어가면 배열과 배열사이에 파라미터값으로 대치한다. 공백을 넣었기 때문에 innerHTML에는 스트링문자열이 자연스럽게 들어가고 렌더링될 때 원하는 결과를 가져온다.
반응형