안녕하세요 오늘은 Next.js에 무엇인지 배워보겠습니다! ╰(°▽°)╯
Next.js는 react 라이브러리의 프레임워크입니다.
새로운 기술이 나오는 이유는 본래 쓰던 기술들의 단점을 보안하기 위해 나온다고 생각합니다.
그렇다면 본래 쓰던 react라이브러리의 단점은 무엇일까요?
리액트는 CSR을 사용합니다.
CSR은 좋지 않은 SEO, 느린 초기 렌더링이라는 단점을 가지고있습니다.
여기서 그 단점을 보안하기위해 SSR+CSR을 모두 쓸 수 있는 next.js라는 기술이 나온겁니다.
next.js는 SSR의 빠른 초기 렌더링과 좋은 SEO(검색 엔진),
CSR의 유연한 페이지 라우팅의 장점을 모두 가지고 있습니다.
SSR(Server Side Rendering)과 CSR(Client Side Rendering)에 대해서 짧게 얘기해보겠습니다.
말 그대로 서버쪽에서 렌더링 준비를 끝내고 클라이언트에게 전달하는 방식입니다.
SSR의 동작 방식입니다.
1. 사용자가 구글에 접속합니다.
(Website에게 요청을 보냄)
2. 요청을 받은 서버는 바로 쓸수 있는 html파일을 줍니다.
3. 클라이언트는 현재 페이지의 html파일을 받고 html의 js파일을 다운받습니다.
4.렌더링 가능한 html을 받았기떄문에 바로 화면이 띄워지고 js가 다운되기전에는 js코드가 작동이 안되지만 다운받은후부터 사용자 조작이 가능합니다.
SSR과 달리 클라이언트쪽에서 렌더링을 담당합니다.
CSR의 동작 방식입니다.
1. 사용자가 구글에 접속합니다.
(Website에게 요청을 보냄)
2. 서버는 접근을 허용하며 빈 html파일을 클라이언트에게 넘겨줍니다.
3. 클라이언트는 html 안에 있는 js를 다운받습니다.
(react는 번들화를 하기떄문에 html안에 js를 다운받게 되면 모든 페이지의 html,js를 다운받게됩니다
그렇기 떄문에 초기렌더링이 오래걸립니다.)
4. 그후 페이지는 사용자 조작이 가능해집니다.
장점
단점
장점
단점
어떤 기술을 공부하기전에 왜 배우는지부터 알아야한다는 생각에
정리해서 블로그 글을 올렸는데 아직 미숙한 부분이 많은거같아요
틀린 부분이나 부족한부분이 있다면 얘기해주시면 참고하겠습니다! ╰(°▽°)╯