(์ ) ํด์น๋ฉ์ค ํ๋ก ํธ์๋ ๊ฐ๋ฐ์
(์ ) ๋ผ์ธ ํ์ด๋ธ์ ํ๋ฐํธ์๋ ๊ฐ๋ฐ์
์ผ์ฑ SSAFY, ํ๋ก๊ทธ๋๋จธ์ค ๋ฑ ํ๋ฐํธ์๋ ๊ฐ๋ฐ ๊ฐ์
์น ์ฑ๋ฅ ์ต์ ํ ํ๋ก์ ํธ ๋ฐ ๊ฐ์ ์ ์
๋ง์ดํฌ๋ก์ํํธ์จ์ด 393ํธ(JS ์ฃผ์ ), 392ํธ(๋ธ๋ก์ฒด์ธ ์ฃผ์ ) ๊ธฐ๊ณ
Courses
Reviews
- Complete Guide to Frontend Build Systems - Part.1: Module System
- Complete Guide to Frontend Build Systems - Part.1: Module System
- Complete Guide to Frontend Build Systems - Part.1: Module System
verumnium5082
ยท
Real-world web performance optimization for frontend developers (feat. React) - Part. 1Real-world web performance optimization for frontend developers (feat. React) - Part. 1- Complete Guide to Frontend Build Systems - Part.1: Module System
Posts
Q&A
์์ ํ๋ก์ ํธ ๊ด๋ จ ์ง๋ฌธ์ ๋๋ค.
์๋ ํ์ธ์, ์น์ฒ ๋ ํน์ ์ค์ต ์๋ฃ ๋ชป ์ฐพ์ผ์ จ๋์?์ค์ต ๋ ํฌ์งํ ๋ฆฌ ์ฃผ์๋ ๊ฐ ์น์ ์ ์ ์์์ ๋งํฌ ๊ฑธ๋ ค์์ต๋๋ค.https://github.com/performance-lecture/lecture-3/https://github.com/performance-lecture/lecture-4/
- 0
- 1
- 19
Q&A
bundle analyzer ์ ๋ํ ์ง๋ฌธ์ด ์์ต๋๋ค.
์๋ ํ์ธ์, ์๋ณ์๋ณ๋๊ฐ๋ฅํ ์๋ ์๊ณ , ๋ถ๊ฐ๋ฅํ ์๋ ์์ต๋๋ค...!๊ฐ์์์๋ bundle-analyzer๋ฅผ CLI๋ก ์คํ์ ํ๋๋ฐ์,๊ทธ๋ฌ์ง ์๊ณ webpack์ plugin์ผ๋ก ์ค์ ํ๊ณ ๋น๋ํ๋ฉด ๋ฉ๋๋ค.๊ทธ๋ฌ๋ฉด ๋น๋ํ๋ฉด์ ๊ทธ ๋น๋ ๋ด์ฉ์ ๋ฆฌํฌํธํ๊ธฐ ๋๋ฌธ์ ํ์ผ๋ช ์ด ์ผ์นํฉ๋๋ค. ๊ฐ์์์๋ ํธ์์ CLI๋ฅผ ์ฌ์ฉํด์ ์ฌ์ด์ฆ์ ํ์ด๋ฐ์ผ๋ก ๊ทธ ์ญํ ์ ๊ตฌ๋ถํด์ผ ํฉ๋๋ค.(๋๋ ์ผ๋ถ ์ฝ๋ ๋ด์ฉ์ ๋ณด๊ณ ๊ตฌ๋ถํ ์ ์์ต๋๋ค!) ๋ต๋ณ์ด ๋์๋์ จ๊ธธ ๋ฐ๋ผ๋ฉฐ, ๊ฐ์์ ๊ด์ฌ์ ๊ฐ์ ธ์ฃผ์ ์ ๊ฐ์ฌํฉ๋๋ค. ๐
- 0
- 2
- 56
Q&A
Cannot find module serve ์๋ฌ
์๋ ํ์ธ์, soyeon๋.ํ์ธํด๋ณด๋ serve ๋ผ์ด๋ธ๋ฌ๋ฆฌ๊ฐ ์ ๋ฐ์ดํธ ๋๋ฉด์ ๋ด๋ถ ๊ตฌ์กฐ๊ฐ ๋ณ๊ฒฝ๋์ด ์ํฅ์ ์ค ๊ฒ ๊ฐ์ต๋๋ค.ํด๋น ์คํฌ๋ฆฝํธ๋ ๋ฐ๋ก ์์ ํด์ master ๋ธ๋์น์ push ํด๋์ต๋๋ค.๋ค์ pull (๋๋ clone) ๋ฐ์ผ์๋ฉด ๋ฉ๋๋ค!์ ๋ณด ๊ฐ์ฌํฉ๋๋ค. ๐์ฐธ๊ณ ๋ก ์์ธ์ ์์ธํ ์ค๋ช ๋๋ฆฌ๋ฉด,๋ง์ํด์ฃผ์ yarn serve ๋ ๋ค์๊ณผ ๊ฐ์ ์คํฌ๋ฆฝํธ๋ฅผ ์คํํฉ๋๋ค.npm run build && node ./node_modules/serve/bin/serve.js -u -s build์ด ๋ serve ํจํค์ง ๋ด๋ถ์ ํ์ผ์ ์ง์ node๋ก ์คํํ๋๋ก ํด๋์๋๋ฐ, ํ์ผ ๊ตฌ์กฐ๊ฐ ๋ณ๊ฒฝ๋๋ฉด์ ์๋ฌ๊ฐ ๋ฐ์ํ์ต๋๋ค.์๋๊ฒฝ๋ก๋ก ๋์ด ์๋ ์คํฌ๋ฆฝํธ๋ฅผ "npm run build && serve -u -s build" ๋ค์๊ณผ ๊ฐ์ด ์์ ํ์ต๋๋ค.
- 1
- 1
- 54
Q&A
๊ฐ๋ฐํ๊ฒฝ์ ๋ํ ์๋ด
์๋ ํ์ธ์, long๋.ํ์ต์ ๋ถํธํจ์ ๋๋ ค ์ ๋ง ์ฃ์กํฉ๋๋ค.๋ง์ํ์ ๋๋ก ๊ฐ์ ํ๊ฒฝ์ ๋ํ ๋ณด์์ ๋น ๋ฅธ ์์ผ ๋ด์ ํด๋๊ฒ ์ต๋๋ค.๊ทธ๋ฆฌ๊ณ ์ด๋ฏธ์ง ๋ํ ์กฐ์น๋ฅผ ์ทจํด๋ณด๊ฒ ์ต๋๋ค.ํน์๋ ์ ๋๋ ๋ถ๋ถ์ด ์์ด ์ง๋ฌธ์ ์ฌ๋ ค์ฃผ์๋ฉด ๋ฐ๋ก ํด๊ฒฐ์ฑ ์ ์์๋ก๋ผ๋ ๊ณต์ ๋๋ฆฌ๊ฒ ์ต๋๋ค.๋ค์ ํ ๋ฒ ๊ฐ์ ํ๊ฒฝ์ด ์ํํ์ง ์์ ์ ์ฌ๊ณผ๋๋ฆฝ๋๋ค.
- 1
- 2
- 118
Q&A
์ฑ๋ฅ ํญ์์ ์์์๊ฐ์ด ์๋ณด์ ๋๋ค
์๋ ํ์ธ์ qjatjs123123๋.์ต๊ทผ์ ์์ค์ฝ๋์ React ๋ฒ์ ์ ์ ๋ฐ์ดํธํ์ต๋๋ค.๋ฆฌ์กํธ 16์ผ๋ก ๋ง๋ ์ฝ๋์๋ค๋ณด๋ ์ต์ ํ๊ฒฝ๋ค๊ณผ ๋ฒ์ ์ด์๊ฐ ์์ด์์.์ด๋ก ์ธํด ์ปดํฌ๋ํธ์ ๋ํ Timing(์์ ์๊ฐ) ์ ๋ณด๊ฐ ์ฌ๋ผ์ก์ต๋๋ค.Timing ์ ๋ณด์ ๋ํด ์ค๋ช ๋๋ฆฌ๋ฉด, Timing ์น์ ์์๋ User Timing API(performance.mark() ๋ฐ performance.measure()) ๋ฅผ ํตํด ๊ธฐ๋ก๋ ์ ๋ณด๋ฅผ ํ์ํด์ค๋๋ค.(์ฐธ๊ณ : https://developer.chrome.com/docs/devtools/performance/reference?hl=ko#timings)React 16 ๋ฒ์ ์์๋ ์ปดํฌ๋ํธ์ ์คํ ์๊ฐ์ Timing API๋ก ๊ธฐ๋กํ์๋๋ฐ, React 17 ๋ฒ์ ์ดํ๋ก ์ ํ์ฑ ๋ฐ ์ ์ง๋ณด์ ๋ฌธ์ ๋ก ์ธํด ์ ๊ฑฐ๋์์ต๋๋ค.๋ฐ๋ผ์ React 19๋ก ๋ฒ์ ์ ์ ๋ฐ์ดํธํ ์ง๊ธ main ์ฝ๋์์๋ ์ปดํฌ๋ํธ์ ํ์ด๋ฐ ์ ๋ณด๋ฅผ ๋ณผ ์ ์์ต๋๋ค.๋ง์ฝ ์ง์ ๋ณด๊ณ ์ถ๋ค๋ฉด, lecture-1์ a3999d1fa4c2bcb3bed97c92fe9892fe5f42a4f8 ์ด ํด์ ์ปค๋ฐ์ผ๋ก ์ฒดํฌ์์ํ์๊ณ ํ์ธํด๋ณด์ค ์ ์์ต๋๋ค. (๋ฒ์ ์ ๋ฐ์ดํธ ์ ์ปค๋ฐ)๋ต๋ณ์ด ๋์ จ๊ธธ ๋ฐ๋ผ๋ฉฐ, ๊ฐ์์ ๊ด์ฌ์ ๊ฐ์ ธ์ฃผ์ ์ ๊ฐ์ฌํฉ๋๋ค! :)
- 0
- 2
- 125
Q&A
layout shift๊ฐ ์์ฃผ ์ฝ๊ฐ ์ผ์ด๋๋ ๋ถ๋ถ์ ๋ํด
์๋ ํ์ธ์, BBB AAA๋.ํ์ธํด๋ณด๋ ํด๋น Layout Shift๋ ์คํฌ๋กค๋ฐ๊ฐ ์๊ธฐ๋ฉด์ ๋ฐ์ํ๋ Layout Shift๋ก ๋ณด์ ๋๋ค.์ด๋ฏธ์ง๋ฅผ ๋ถ๋ฌ์ค๋ฉด ์คํฌ๋กค์ด ์๊ธฐ๋ ๊ทธ ์๊ฐ์ด ๊ธฐ๋ก๋ ๊ฒ์ ๋๋ค.๊ฒฐ๋ก ์ ์ผ๋ก ๋ง์๋๋ฆฌ๋ฉด,Layout Shift๊ฐ ๋ฐ์ํ ๊ฒ์ ๋ง๊ณ , ๊ทธ ์์น๊ฐ ๋๋ฌด ์์(0.00014639456069971026) Lighthouse์์๋ ์ ๋๋ก ํ๊ธฐ๊ฐ ์ ๋ ๊ฒ ๊ฐ์ต๋๋ค.์ง์ ํ์ธํ ์ ์๋ ๋ฐฉ๋ฒ์ ๋ค์๊ณผ ๊ฐ์ต๋๋ค.Lighthouse๋ก ๊ฒ์ฌ๋ฅผ ํ ๋ค, ์ค๋ฅธ์ชฝ ์ ... ๋ฒํผ์์ JSON์ผ๋ก ๋ค์ด๋ก๋๋ฅผ ๋ฐ์ต๋๋ค.(์ฌ์ง) ๊ทธ ํ, ํด๋น ํ์ผ์ ์ด์ด "cumulative-layout-shift"๋ฅผ ๊ฒ์ํด๋ณด๋ฉด ๋ค์ ์ด๋ฏธ์ง์ ๊ฐ์ ๋ฐ์ดํฐ๋ฅผ ํ์ธํ ์ ์์ต๋๋ค.(์ฌ์ง)์ฆ, ์ค์ ๋ฐ์ดํฐ๋ 0.00014639456069971026 (numericValue) ์ด์ง๋ง, displayValue๋ 0์ผ๋ก ์๋ง ๋ฐ์ฌ๋ฆผ ๋ ๊ฒ์ผ๋ก ๋ณด์ ๋๋ค.(์ง์ Lighthouse์์ displayValue๋ฅผ ์ด๋ป๊ฒ ๊ณ์ฐํ๋์ง ํ์ธํด๋ณด์ง ์์์ง๋ง, ์์์ ๋์งธ ์๋ฆฌ๊น์ง ๋ฐ์ฌ๋ฆผํ๋๊ฒ ์๋๊ฐ ์ถ์ต๋๋ค.)๊ทธ๋ผ ๋ต๋ณ์ด ๋์๋์ จ๊ธธ ๋ฐ๋ผ๋ฉฐ, ๊ฐ์์ ๊ด์ฌ์ ๊ฐ์ ธ์ฃผ์ ์ ๊ฐ์ฌํฉ๋๋ค! :)
- 0
- 2
- 208
Q&A
3-4) ์ด๋ฏธ์ง ์ฌ์ด์ฆ ์ต์ ํ ๊ณผ์ ์์ img ํ๊ทธ ์๋ ์๋๋ ๋ฌธ์
์๋ ํ์ธ์, ํคํค๋์ด๋ฏธ์ง ์๋ฌ์ ๋ํด์ ์ง๋ฌธ์ ์ฃผ์ จ๋๋ฐ์์ ๊ฐ ํ์ธํด๋ณด๋, picture, source ํ๊ทธ์์์ ์ด๋ฏธ์ง ํด๋ฐฑ์ type ๊ฐ์ ๊ธฐ์ค์ผ๋ก ์ฒ๋ฆฌ๋ฉ๋๋ค.์ฆ, type ๊ฐ์ ๊ธฐ์ค์ผ๋ก ๋จผ์ ์ด๋ค ์ด๋ฏธ์ง(source)๋ฅผ ๋ ๋๋งํ ์ง ํ๋จํ๊ณ ํด๋น ์ด๋ฏธ์ง๋ฅผ ํ์ํฉ๋๋ค.๋ฐ๋ผ์ type="image/webp"๋ผ๋ฉด ์ด๋ฏธ์ง ์ฃผ์์ ์๋ฌ๊ฐ ์๋ ์๋ srcset์ ์ด๋ฏธ์ง๋ฅผ ๋ ๋๋ง ํฉ๋๋ค.์ด๋ ์ด๋ฏธ์ง์ ์๋ฌ๊ฐ ๋ฐ์ํ๋ฉด ๊ทธ๋ฅ ์๋ฐ์ ๋ณด์ฌ์ฃผ๊ณ (์ฌ์ง) ํ๊ทธ์ onerror(onError) ์ด๋ฒคํธ๊ฐ ๋ฐ์ํ๋ ์์ ๋๋ค.์ ๊ฐ์์์๋ srcset ์ "s"๋ฅผ ๋ถ์ฌ์ฃผ๋ ๊ฒ ๋ฟ๋ง ์๋๋ผ type ๋ํ ์ด์ํ ๊ฐ์ผ๋ก ๋ฐ๊ฟ์คฌ๊ธฐ ๋๋ฌธ์ ์ง์ํ์ง ์๋ ์ด๋ฏธ์ง ํ์ ์ผ๋ก ํ๋จํ์ฌ (์ฌ์ง) ํ๊ทธ์ ์ด๋ฏธ์ง๋ฅผ ๋ณด์ฌ์ค ๊ฒ์ ๋๋ค.(์ฆ, source ํ๊ทธ์ ํด๋ฐฑ์ srcset ๊ฐ์ ์๋ฌ ์ ๋ฌด์๋ ๋ฌด๊ดํฉ๋๋ค.)๊ฒฐ๋ก ์ ์ผ๋ก ์ง์ ํด๋ณด์ค ๋, type๊ฐ์ ์ด์ํ ๊ฐ์ผ๋ก ๋ณ๊ฒฝํด์ ํ ์คํธ ํด๋ณด์๊ธธ ๋ฐ๋๋๋ค.๊ฐ์์์ ์ค๋ช ์ด ๋ถ์กฑํ ๋ถ๋ถ์ผ๋ก ํผ๋์ ๋๋ ค ์ฃ์กํฉ๋๋ค. ใ ๋ต๋ณ์ด ๋์๋์ จ๊ธธ ๋ฐ๋ผ๋ฉฐ, ๊ฐ์์ ๊ด์ฌ์ ๊ฐ์ ธ์ฃผ์ ์ ๊ฐ์ฌํฉ๋๋ค. :)
- 0
- 2
- 217
Q&A
Material--icons_4.0.0.woff2
์๋ ํ์ธ์, lab ajung ๋.๋ง์ํ์ Material--icons_4.0.0.woff2์ ์ถ์ฒ๊ฐ ์ด๋์ผ๊น์?์ฐพ์๋ดค์ง๋ง, Material icons ์์ ์ ๋ฐ ํํ๋ก ์ ๊ณตํ๋๊ฑด ๋ชป์ฐพ๊ฒ ๋ค์.(https://github.com/google/material-design-icons/tree/master/font)์ฐ์ ์์ด์ฝ์ ์ธ ๋ ํฐํธ๋ก๋ ๊ฑฐ์ ์ฌ์ฉํด๋ณด์ง ์์์ ์์ ๋ชจ๋ฅด๊ฒ ์ง๋ง,๊ณต์ ๊ฐ์ด๋์์ ์ด๋ป๊ฒ ์ต์ ํ๋ฅผ ํ ์ ์๋์ง๋ฅผ ์ฐพ์๋ณด์๋ฉด ์ข์ ๊ฒ ๊ฐ์ต๋๋ค.๊นํ๋ธ ์ด์๋ผ๋๊ฐ ์ฐพ์๋ณด์๋ฉด ์์ง ์์๊น ์๊ฐ๋ฉ๋๋ค.์ ๊ฐ ๋ง์ฝ ์ต์ ํ๋ฅผ ํ๋ค๋ฉด,ํ์ํ ์์ด์ฝ๋ง ์ถ์ถ(subset)ํ์ฌ ์ฌ์ฉ๊ฐ๋ฅํ๋ค๋ฉด ํฐํธํํ๊ฐ ์๋ svgํํ๋ก ์์ ํ์ํ ๊ฒ๋ง ์ฌ์ฉํ๋ ํํ๋ก ๋ณ๊ฒฝpreload ์ ์ฉ ์ด ์ ๋ ๊ณ ๋ คํด๋ณผ ์ ์์ง ์์๊น ์๊ฐ๋ฉ๋๋ค.๊ทธ๋ผ ๋์์ด ๋์ จ๊ธธ ๋ฐ๋ผ๋ฉฐ, ๊ฐ์์ ๊ด์ฌ์ ๊ฐ์ ธ์ฃผ์ ์ ๊ฐ์ฌํฉ๋๋ค! :)
- 0
- 1
- 168
Q&A
์ด๋ฏธ์ง CDN ๋ง๋๋ ๋ฐฉ๋ฒ
์๋ ํ์ธ์, ์ ๋๋ฒ๋. ์ด ๊ฐ์์์๋ ์ด๋ฏธ์ง CDN์ ๋ง๋๋ ๋ฒ๋ฒ์ ๋ํด์๋ ๋ฐ๋ก ๋ค๋ฃจ์ง ์์ต๋๋ค ใ ๋ค๋ฅธ ๊ฐ์๋ฅผ ์ฐพ์๋ณด์๊ฑฐ๋ ๋ธ๋ก๊ทธ ๊ธ์ ์ฐพ์๋ณด์๋ฉด ๋์์ด ๋์ค ๊ฒ ๊ฐ์ต๋๋ค.
- 0
- 1
- 389
Q&A
์ฝ๋ ์คํ ์ ์๋ฌ ๊ด๋ จ ์ง๋ฌธ๋๋ฆฝ๋๋ค!!
์๋ ํ์ธ์, ์ง์๋.๋ค์๊ณผ ๋์ผํ ์ด์๋ก ๋ณด์ ๋๋ค.https://www.inflearn.com/questions/735601/node-version%EC%9C%BC%EB%A1%9C-%EC%9D%B8%ED%95%9C-%EC%98%A4%EB%A5%98
- 1
- 1
- 536