📕 Note
[개발일기] 2022 웹개발 로드맵 총정리
yeossi
2022. 1. 20. 11:19
내용 출처 : https://www.youtube.com/watch?v=TTLHd3IyErM
- front-end 개발자가 되기 위해선 총 다섯가지를 학습해야한다
- basic tools : 개발을 하기 위한 기본적인 툴
- Computer
- MacOS
- Windows
- Linux
- Text Editor
- VS Code : 강력한 extend와 무료 라이센스가 큰 장점
- IntelliJ : 강력한 리팩토링 기능까지 지원하나 라이센스를 별도로 구입해야 함
- Atom
- Sublime Text
- Browser
- Chrome
- Edge
- Safari
- Firefox
- Terminal
- Powershell
- Bash
- zsh
- Computer
- front-end : 프론트엔드 스킬
- HTML
- HTML은 웹의 Structure이다.
- Tags
- Page Structure
- Semantic Tags : 이름 자체만으로 브라우저나 길 잃은 사람들, 지구 상의 원주민, 개발자, 수정자들에게 의미를 전달할 수 있는 태그
- SEO : 검색엔진 최적화
- Accessibility : 접근성
- ★★★JavaScript
- JS는 웹의 Behavior이다.
- ES6 + Syntax
- Basic
- let, const
- if, for, switch, while
- function
- object
- Advanced
- Prototype
- Hoisting
- Scope
- Closure
- Basic
- Browser APIs
- DOM Manipulation : 돔 요소를 어떻게 조작해야 할 지
- Events : 어떻게 이벤트를 사용할 수 있는 지
- Fetch API(Async) : fetch api를 통해 어떻게 서버에 있는 데이터를 가지고 올 수 있는 지
- TypeScript : Type이 감싸고 있는 자바스크립트 프로그래밍 언어. 자바스크립트에비해 안전성이 추가됐으며 유지보수성이 높음. 규모가 큰 프로젝트에서는 무조건 사용
- Types
- OOP
- JavascriptFramework
- React
- Vue
- Angular
- Svelte : 점점 성장하고 있는 프레임워크. React에서 Svelte의 장점을 반영시키려는 움직임이 있다고 함.
- Static Site Generators (SSG) : 정적 사이트 생성기. 말 그대로 정적 페이지 기반 웹사이트를 만들어주는 도구이다. 컨텐츠 및 파일을 읽어 이를 html으로 변환시키는 기술을 제공한다. 이는 주로 회사 소개 글 또는 블로그 글처럼 내용이 변하지 않는, 즉 동적인 사이트가 아닌 웹페이지를 만들 때 사용한다.Gatsby의 구성도
- Gatsby(React)
- GridSome(Vue)
- Ilty(JS)
- Server Side Rendering(SSR) : 클라이언트에 요청이 있을 때 실시간으로 서버에서 페이지를 만들어주는 도구이다.
- Next.js(React)
- Nuxt.js(Vue)
- Universal(Angular)
- Sapper(Svelte)
- CSS
- CSS는 웹의 Presentation이다.
- Styling
- Layouts
- Responsive Design : 반응형 디자인
- Animation
- Architecture
- BEM : css로만 스타일을 정의할 경우 이름 등 여러가지 속성이 겹치며 충돌이 나는 경우가 있는데 이를 방지하기 위해 css에서 어떻게 클래스를 정의하면 좋을 지 정의한 아키텍쳐.
- Preprocessors : CSS 전처리기. 반복적으로 정의하는 css를 방지하기 위해 등장. 변수처리가 가능함. 부모 자식 선택자가 있기 때문에 부모 > 자식으로 반복되는 css가 여러개 생성되는 것을 막을 수 있음. 모듈, 믹싱, 함수 또한 제공하고 있음.
- Sass
- Less
- PostCSS
- CSS Framework : 이미 만들어진 UI가 존재함
- Bootstrap
- PostCSS
- Tailwind CSS
- Material UI
- Styled-Components : JS에 스타일을 정리하면 동적으로 스타일을 변경할 수 있어서 좋지만, 성능면에서 비교적 안 좋으며 비즈니스모델이 들어있는 JS에 style이 들어가기 때문에 유지보수가 까다롭고 보기에도 안 좋은 단점도 있다.
- Bootstrap, Tailwind CSS, Material UI는 미리 만들어져있어서 제공되는 컴포넌트를 가져다 쓰는 프레임워크이며 PostCSS, Styled-Components는 직접 CSS를 커스터마이징해서 사용하는 프레임워크이다.
- HTML
- tools : 더 다양한 툴 (front-end와 병행해서 공부)
- Version Control System
- Git
- GitHub
- Bitbucket
- GitLab
- Git
- Package Manager : npm과 yarn은 상호 호환이 가능함
- npm
- yarn
- Module Bundler : 소스를 배포할 때 압축, 배제, 용량 감축 등 배포시 보여줄 파일들을 정리하는 도구. JS Framework에서 자동으로 해줌.
- Webpack
- Rollup
- Parcel
- Version Control System
- testing : 배포하기 전 테스트(더 나아가 자동화까지 할 것)
- Test Pyramid
- Jest
- Cypress
- Enzyme
- react-testing-library
- Good Test Principles
- CI / CD
- Test Pyramid
- publish : 배포
- Azure
- Github Pages
- Vercel
- AWS
- Netlify
- Heroku
- basic tools : 개발을 하기 위한 기본적인 툴