ํ๊ฐ์ง ๋จ์ํ ๊ท์น: "์ฑ๋ฅ์ ๊ณ ๋ คํ ์ค๊ณ์ ์ฝ๋"
ย ย ย ย ย ย ย ย ย ย ย ย ย ย ย ย
ย How To Use โข Contributing
๐จ๐ณ ๐ซ๐ท ๐ฐ๐ท ๐ต๐น ๐ท๐บ
Other Checklists:
๐ Front-End Checklist โข ๐ Front-End Design Checklist
- HTML
- CSS
- Fonts
- Images
- JavaScript
- Server (in progress)
- JS Frameworks (in progress)
์ฑ๋ฅ์ ๊ฑฐ๋ํ ์ฃผ์ ์ง๋ง, ํญ์ "๋ฐฑ์๋"๋ "์ด๋๋ฏผ"์๋ง ๊ตญํ๋๋ ์ฃผ์ ๋ ์๋๋๋ค: ํ๋ก ํธ์๋๋ ์ฑ๋ฅ์ ๋ํ ์ฑ ์์ด ์์ต๋๋ค. ํ๋ก ํธ์๋ ์ฑ๋ฅ ์ฒดํฌ๋ฆฌ์คํธ๋ ํ๋ก ํธ์๋ ๊ฐ๋ฐ์๋ก์ ์ต์ํ ์์์ผํ๊ฑฐ๋ ์ฒดํฌํด์ผํ ์์๋ค์ ๋ชฉ๋ก์ด๋ฉฐ, ํ๋ก์ ํธ์ ์ ์ฉํด์ผ ํ๋ ๊ฒ์ ๋๋ค.
๊ฐ ๊ท์น์ ์ ์ด ๊ท์น์ด ์ค์ํ๊ณ ์ด๋ป๊ฒ ๊ณ ์น ์ ์๋์ง ์ค๋ช ํ๊ณ ์์ต๋๋ค. ๋ง์ฝ ๋ ์์ธํ ์ ๋ณด๋ฅผ ์ป๊ณ ์ถ๋ค๋ฉด, ์ฒดํฌ๋ฆฌ์คํธ๋ฅผ ์์ฑ์ํฌ ์ ์๋ ๐ ํด, ๐ ์ํฐํด, ๐น ๋ฏธ๋์ด๋ฅผ ๊ฐ๋ฆฌํค๋ ๋งํฌ๋ฅผ ์ฐพ์์ผ ํฉ๋๋ค.
ํ๋ก ํธ์๋ ์ฑ๋ฅ ์ฒดํฌ๋ฆฌ์คํธ์ ๋ชจ๋ ํญ๋ชฉ์ ์ต๊ณ ์ ์ฑ๋ฅ์ ๋ด๋๋ฐ ํ์์ ์ด์ง๋ง, ์ผ๋ถ ๊ท์น์ ์ฐ์ ์์๋ฅผ ์ ํ๋๋ฐ ๋์์ ์ฃผ๊ธฐ ์ํด ์ฐ์ ์์/์ํฅ์ 3๊ฐ์ง ๋ ๋ฒจ๋ก ๊ตฌ๋ถํ์ต๋๋ค:
- ๋ ํด๋น ํญ๋ชฉ์ด ํ๋ก์ ํธ์ ๋ฎ์ ์ฐ์ ์์์ ์ํฅ์ ๊ฐ์ง๋ค๋ ์๋ฏธ์ ๋๋ค.
- ์ ํด๋น ํญ๋ชฉ์ด ํ๋ก์ ํธ์ ์ค๊ฐ ์ ๋์ ์ฐ์ ์์์ ์ํฅ์ ๊ฐ์ง๋ค๋ ์๋ฏธ์ ๋๋ค. ์ด ํญ๋ชฉ์ ๋ํด ๊ณ ๋ฏผํ๋ ๊ฒ์ ํผํด์ ์ ๋ฉ๋๋ค.
- ๋ ํด๋น ํญ๋ชฉ์ด ํ๋ก์ ํธ์ ๋์ ์ฐ์ ์์์ ์ํฅ์ ๊ฐ์ง๋ค๋ ์๋ฏธ์ ๋๋ค. ์ด ๊ท์น์ ํผํ ์ ์์ผ๋ฉฐ, ์์ ์ฌํญ์ ์ ์ฉํด์ผ ํฉ๋๋ค.
์น์ฌ์ดํธ๋ ์ดํ๋ฆฌ์ผ์ด์ ์ ๋ชจ๋ํฐ๋งํ๊ณ ํ ์คํธํ ๋ ์ฌ์ฉํ ์ ์๋ ๋๊ตฌ๋ค์ ๋๋ค:
- ๐ WebPagetest - Website Performance and Optimization Test
- ๐ โ Dareboost: Website Speed Test and Website Analysis (use the coupon WPCDD20 for -20%)
- ๐ GTmetrix | Website Speed and Performance Optimization
- ๐ PageSpeed Insights
- ๐ Pingdom Website Speed Test
- ๐ Pagespeed - The tool and optimization guide
- ๐ Make the Web Faster | Google Developers
- ๐ Sitespeed.io - Welcome to the wonderful world of Web Performance
- ๐ Calibre
- ๐ Website Speed Test | Check Web Performance ยป Dotcom-Tools
- ๐ Website and Server Uptime Monitoring - Pingdom (Free Signup Link)
- ๐ Uptime Robot
- ๐ SpeedCurve: Monitor front-end performance
- ๐ PWMetrics - CLI tool and lib to gather performance metrics
- ๐ Varvy - Page speed optimization
- ๐น The Cost Of JavaScript - YouTube (text version)
- ๐ Get Started With Analyzing Runtime Performance | Google Developers
- ๐ State of the Web | 2018_01_01
- ๐ Page Weight Doesn't Matter
- ๐ Varvy - Web performance glossary
- ๐ fabkrum/web-performance-resources: Up to date collection of valuable web performance resources
-
HTML ์์ถ: HTML ์ฝ๋๋ฅผ ์์ถํ๊ณ , ์ต์ข ํ์ผ์์ ์ฃผ์, ๊ณต๋ฐฑ, ์ค๋ฐ๊ฟ์ ์ ๊ฑฐํฉ๋๋ค.
์:
๋ถํ์ํ ๊ณต๋ฐฑ, ์ฃผ์, ๊ฐํ์ ์ ๊ฑฐํ๋ฉด HTML์ ํฌ๊ธฐ๋ฅผ ์ค์ด๊ณ ํ์ด์ง์ ๋ก๋ฉ ์๋๋ฅผ ๋์ผ ์ ์์ต๋๋ค.๊ทธ๋ฆฌ๊ณ ์ฌ์ฉ์์ ๋ค์ด๋ก๋ ์๊ฐ์ ์ค์ผ ์ ์์ต๋๋ค.
์ด๋ป๊ฒ:
๋๋ถ๋ถ์ ํ๋ ์์ํฌ์๋ ์นํ์ด์ง๋ฅผ ์์ถ์ํค๋ ํ๋ฌ๊ทธ์ธ์ด ์์ผ๋ฉฐ, ์ฌ๋ฌ NPM ๋ชจ๋์ ์ฌ์ฉํด ์ด ์์ ์ ์๋์ผ๋ก ์ฒ๋ฆฌํ ์ ์์ต๋๋ค.
-
๋ถํ์ํ ์ฃผ์ ์ ๊ฑฐ: ํ์ด์ง์์ ์ฃผ์์ด ์ง์์ก๋์ง ํ์ธํฉ๋๋ค.
์:
์ฃผ์์ ์ฌ์ฉ์์๊ฒ ํ์ํ์ง ์๊ธฐ ๋๋ฌธ์ ์ต์ข ํ์ผ์์ ์ง์์ ธ์ผ ํฉ๋๋ค. ๋ผ์ด๋ธ๋ฌ๋ฆฌ์ ์๋ณธ์ ์ ์งํ๊ณ ์ถ์ ๊ฒฝ์ฐ์๋ ์ฃผ์์ ๋จ๊ฒจ๋ ์ ์์ต๋๋ค.
์ด๋ป๊ฒ:
๋๋ถ๋ถ์ ๊ฒฝ์ฐ HTML ์์ถ ํ๋ฌ๊ทธ์ธ์ ์ฌ์ฉํด ์ฃผ์์ ์ง์ธ ์ ์์ต๋๋ค.
-
๋ถํ์ํ ์์ฑ ์ ๊ฑฐ:
type="text/javascript"
์ด๋type="text/css
์ ๊ฐ์ ํ์ ์์ฑ์ ๋ ์ด์ ํ์ํ์ง ์์ผ๋ฉฐ, ์ง์์ผ ํฉ๋๋ค.<!-- Before HTML5 --> <script type="text/javascript"> // Javascript code </script> <!-- Today --> <script> // Javascript code </script>
์:
HTML5๋ text/css์ text/javascript๋ฅผ ๊ธฐ๋ณธ์ผ๋ก ์ง์ํ๊ธฐ ๋๋ฌธ์ ํ์ ์์ฑ์ด ๋ถํ์ํฉ๋๋ค. ์น์ด๋ ์ฑ์์ ์ฌ์ฉ๋์ง ์๋ ์ฝ๋๋ ์ง์์ผ ํ๋ฉฐ, ๋ถํ์ํ ์ฝ๋๋ ํ์ด์ง๋ฅผ ๋ฌด๊ฒ๊ฒ ๋ง๋ญ๋๋ค.
์ด๋ป๊ฒ:
<link>
์<script>
์ ํ์ ์์ฑ์ด ๋จ์ ์๋์ง ํ์ธํ์ธ์.- ๐ The Script Tag | CSS-Tricks ย ย ย
-
CSS ํ๊ทธ๋ฅผ ์๋ฐ์คํฌ๋ฆฝํธ ํ๊ทธ ์์ ๋๊ธฐ: CSS๊ฐ ํญ์ ์๋ฐ์คํฌ๋ฆฝํธ ์ฝ๋ ์ ์ ๋ก๋๋๋์ง ํ์ธํ์ธ์.
<!-- Not recommended --> <script src="jquery.js"></script> <script src="foo.js"></script> <link rel="stylesheet" href="foo.css"/> <!-- Recommended --> <link rel="stylesheet" href="foo.css"/> <script src="jquery.js"></script> <script src="foo.js"></script>
์:
์๋ฐ์คํฌ๋ฆฝํธ ์ ์ CSS ํ๊ทธ๋ฅผ ๋๋ฉด ๋ธ๋ผ์ฐ์ ์ ๋ ๋๋ง ์๋๋ฅผ ๋์ด๋ ๋ณ๋ ฌ ๋ค์ด๋ก๋๊ฐ ๊ฐ๋ฅํด์ง๋๋ค.
์ด๋ป๊ฒ:
<head>
์<link>
์<style>
์ด<script>
์์ ์๋์ง ํ์ธํ์ธ์. -
iframe ์ต์ํ: ๋ค๋ฅธ ๊ธฐ์ ์ ๊ฐ๋ฅ์ฑ์ด ์์ ๋๋ง iframe์ ์ฌ์ฉํ๊ณ , ์ต๋ํ iframe์ ์ฌ์ฉํ์ง ์๋๋ก ํ์ธ์.
-
CSS ์์ถ: CSS ํ์ผ์ ์์ถํ๊ณ , ์ต์ข ํ์ผ์์ ์ฃผ์, ๊ณต๋ฐฑ, ์ค๋ฐ๊ฟ์ ์ ๊ฑฐํฉ๋๋ค.
์:
CSS ํ์ผ์ ์์ถํ๋ฉด ํด๋ผ์ด์ธํธ์๊ฒ ๋ ์ ์ ๋ฐ์ดํฐ๋ฅผ ์ ์กํ๊ฒ ๋๋ฉฐ, ์ฝํ ์ธ ๊ฐ ๋ ๋นจ๋ฆฌ ๋ก๋๋ฉ๋๋ค. CSS ํ์ผ์ ์์ถํ๋ ๊ฒ์ ์ค์ํ ์ผ์ ๋๋ค. ์ด๋ ๋์ญํญ๊ณผ ๋ฆฌ์์ค ์ฌ์ฉ์ ์ค์ด๊ณ ์ ํ๋ ๋ชจ๋ ๋น์ฆ๋์ค์ ๋์์ด ๋ฉ๋๋ค.
์ด๋ป๊ฒ:
๊ฐ๋ฐ์ด๋ ๋น๋ ์ค, ๋๋ ๊ทธ ์ ์ ํ์ผ์ ์๋์ผ๋ก ์์ถํด์ฃผ๋ ํด์ ์ฌ์ฉํ์ธ์.
-
ํฉ์น๊ธฐ: ์ฌ๋ฌ CSS ํ์ผ๋ค์ ํ๋์ ํ์ผ๋ก ํฉ์น์ธ์. (HTTP/2 ์์๋ ํญ์ ์ ํจํ์ง ์์ต๋๋ค.).
<!-- Not recommended --> <script src="foo.js"></script> <script src="ajax.js"></script> <!-- Recommended --> <script src="combined.js"></script>
์:
์ฌ์ ํ HTTP/1์ ์ฌ์ฉํ๊ณ ์๋ค๋ฉด ํ์ผ์ ํฉ์น ํ์๊ฐ ์์ต๋๋ค. ๋ค๋ง ์๋ฒ๊ฐ HTTP/2๋ผ๋ฉด ๊ผญ ๊ทธ๋ ์ง ์์ต๋๋ค. (ํ ์คํธ๋ฅผ ํด๋ด์ผ ํฉ๋๋ค.)
์ด๋ป๊ฒ:
๊ฐ๋ฐ์ด๋ ๋น๋ ์ค, ๋๋ ๊ทธ ์ ์ ํ์ผ์ ํฉ์ณ์ฃผ๋ ์จ๋ผ์ธ ํด, ํ๋ฌ๊ทธ์ธ์ ์ฌ์ฉํ์ธ์. โ ๋ฌผ๋ก ํฉ์น๋ ์์ ์ด ํ๋ก์ ํธ๋ฅผ ๋ฐฉํดํ์ง๋ ์๋๋ก ํ์ธ์.
-
Non-blocking: DOM์ด ๋ก๋๋๋๋ฐ ์๊ฐ์ด ๊ฑธ๋ฆฌ์ง ์๋๋ก CSS ํ์ผ์ non-blocking ๋์ด์ผ ํฉ๋๋ค.
<link rel="preload" href="global.min.css" as="style" onload="this.rel='stylesheet'"> <noscript><link rel="stylesheet" href="global.min.css"></noscript>
์:
CSS ํ์ผ์ ํ์ด์ง ๋ก๋์ ๋ ๋๋ง์ ์ง์ฐ์ํฌ ์ ์์ต๋๋ค.
preload
๋ฅผ ํตํด ๋ธ๋ผ์ฐ์ ๊ฐ ํ์ด์ง์ ์ฝํ ์ธ ๋ฅผ ๋ณด์๊ธฐ ์ ์ CSS ํ์ผ์ ๋ก๋ํ ์ ์์ต๋๋ค.์ด๋ป๊ฒ:
rel
์์ฑ์ ๊ฐ์preload
๋ก ์ฃผ๊ณ ,as="style"
๋ฅผ<link>
ํ๊ทธ์ ๋ฃ์ต๋๋ค. -
CSS ํด๋์ค์ ๊ธธ์ด: ํด๋์ค์ ๊ธธ์ด๊ฐ HTML๊ณผ CSS ํ์ผ์ (๊ฒฐ๊ณผ์ ์ผ๋ก) ์ํฅ์ ์ค ์ ์์ต๋๋ค.
์:
์ฑ๋ฅ ์ํฅ์ ๋ฌธ์ ์ ์ฌ์ง๊ฐ ์์ผ๋ฉฐ, ์ด๋ฆ์ ์ง๋ ์ ๋ต์ ๊ฒฐ์ ํ๋ ๊ฒ์ ์คํ์ผ์ํธ์ ์ ์ง๊ด๋ฆฌ์ ์๋นํ ์ํฅ์ ๋ฏธ์น ์ ์์ต๋๋ค. ๋ง์ฝ BEM์ ์ฌ์ฉํ๊ณ ์๋ค๋ฉด, ๊ฒฝ์ฐ์ ๋ฐ๋ผ ํด๋์ค ์ด๋ฆ์ ํ์ ์ด์์ ๋ฌธ์๋ฅผ ์ฌ์ฉํ ์ ์์ต๋๋ค. ์ด๋ฆ์ ํ๋ช ํ๊ฒ ์ ํ๋ ๊ฒ์ ์ธ์ ๋ ์ค์ํ ์ผ์ ๋๋ค.
์ด๋ป๊ฒ:
๋ฌธ์์ ๊ธธ์ด์ ์ ํ์ ๋๋ค๋ ๊ฒ์ด ๋๊ตฐ๊ฐ์๊ฒ๋ ํฅ๋ฏธ๋ก์ธ ์ ์์ต๋๋ค๋ง, ์น์ฌ์ดํธ๋ฅผ ์ฌ๋ฌ ์ปดํฌ๋ํธ๋ก ๋ถ๋ฆฌํ๋ฉด ํด๋์ค์ ํด๋์ค์ ๊ธธ์ด๋ฅผ ์ค์ด๋๋ฐ ๋์์ด ๋ ์ ์์ต๋๋ค.
-
์ฌ์ฉ๋์ง ์๋ CSS: ์ฌ์ฉ๋์ง ์๋ CSS ์ ํ์๋ฅผ ์ง์ฐ์ธ์.
์:
์ฌ์ฉํ์ง ์๋ CSS ์ ํ์๋ฅผ ์ง์ฐ๋ฉด ํ์ผ์ ํฌ๊ธฐ๋ฅผ ์ค์ผ ์ ์์ผ๋ฉฐ, ๋ก๋ฉ ์๋๋ฅผ ๋์ผ ์ ์์ต๋๋ค.
์ด๋ป๊ฒ:
โ ๏ธ ํญ์ ์ฌ์ฉํ๋ ค๋ CSS ํ๋ ์์ํฌ์ ์ด๋ฏธ reset / normalize ์ฝ๋๊ฐ ํฌํจ๋์ด์์ง ์์์ง ์ฒดํฌํ์ธ์. ๊ฒฝ์ฐ์ ๋ฐ๋ผ reset / normalize ํ์ผ์ ์๋ ๊ฒ์ด ํ์ํ์ง ์์ ์๋ ์์ต๋๋ค.- ๐ UnCSS Online
- ๐ PurifyCSS
- ๐ PurgeCSS
- ๐ Chrome DevTools Coverage
-
CSS ํฌ๋ฆฌํฐ์ปฌ: CSS ํฌ๋ฆฌํฐ์ปฌ (๋๋ "์ด๋ณด๋ธ ๋ ํด๋")์ ํ์ด์ง์ ๋ณด์ด๋ ๋ถ๋ถ์ ๋ ๋๋งํ๋ ๋ฐ ์ฌ์ฉ๋๋ ๋ชจ๋ CSS๋ฅผ ์์งํฉ๋๋ค. ์ด๋ ์ฃผ์ CSS ํธ์ถ ์ , ๊ทธ๋ฆฌ๊ณ
<style></style>
์ฌ์ด์ ํ ์ค๋ก ์๋ฒ ๋๋๋ฉ๋๋ค. (๊ฐ๋ฅํ๋ฉด ์์ถ๋ฉ๋๋ค.)์:
CSS ํฌ๋ฆฌํฐ์ปฌ์ ๋ฃ์ผ๋ฉด ์๋ฒ ์์ฒญ์ ์ค์ฌ ์น ํ์ด์ง์ ๋ ๋๋ง ์๋๋ฅผ ๋์ผ ์ ์์ต๋๋ค.
์ด๋ป๊ฒ:
์จ๋ผ์ธ ํด์ด๋ Addy Osmani๊ฐ ๊ฐ๋ฐํ ๊ฒ๊ณผ ๊ฐ์ ํ๋ฌ๊ทธ์ธ์ ์ฌ์ฉํด CSS ํฌ๋ฆฌํฐ์ปฌ์ ์์ฑํ์ธ์.
-
์ธ๋ถ ๋๋ ์ธ๋ผ์ธ CSS: ์ธ๋ถ ๋๋ ์ธ๋ผ์ธ CSS๋ฅผ
<body>
์์ ๋์ง ๋ง์ธ์. (HTTP/2์์๋ ์ ํจํ์ง ์์ต๋๋ค.)์:
์ด๋ ๊ฒ ํด์ผํ๋ ์ฒซ ๋ฒ์งธ ์ด์ ๋ ๋์์ธ์์ ์ฝํ ์ธ ๋ฅผ ๋ถ๋ฆฌํ๋ ๊ฒ์ด ์ข์ ๊ดํ์ด๊ธฐ ๋๋ฌธ์ ๋๋ค. ๋ํ ์ด๋ ์ฝ๋ ์ ์ง๋ณด์๋ฅผ ์ฝ๊ฒ ๋ง๋ค๊ณ ์ฌ์ดํธ ์ ๊ทผ์ฑ์ ๋์ด๋ ๋ฐ๋ ๋์์ด ๋ฉ๋๋ค. ์ฑ๋ฅ๊ณผ ๊ด๋ จํด์๋, ์ด๊ฒ์ด HTML ํ์ด์ง์ ํ์ผ ํฌ๊ธฐ์ ๋ก๋ฉ ์๊ฐ์ ์ค์ด๊ธฐ ๋๋ฌธ์ ๋๋ค.
์ด๋ป๊ฒ:
ํญ์ ์ธ๋ถ ์คํ์ผ ์ํธ๋ฅผ ์ฌ์ฉํ๊ฑฐ๋ CSS๋ฅผ
<head>
์ ์๋ฒ ๋ํ์ธ์. (๊ทธ๋ฆฌ๊ณ ๋ค๋ฅธ CSS ์ฑ๋ฅ ๊ท์น์ ๋ฐ๋ฅด์ธ์.) -
์คํ์ผ์ํธ ๋ณต์ก๋ ๋ถ์: ์คํ์ผ์ํธ๋ฅผ ๋ถ์ํ๋ ๊ฒ์ ๋ถํ์ํ ์ค๋ณต CSS ์ ํ์๋ฅผ ์ฐพ๋ ๋ฐ ๋์์ด ๋ฉ๋๋ค.
์:
์ข ์ข ์ค๋ณต, ๋๋ ์ ํจ์ฑ ์๋ฌ๊ฐ CSS ์ฝ๋์์ ๋ฐ์ํ ์ ์๋๋ฐ, CSS ํ์ผ์ ๋ถ์ํ๊ณ ๋ณต์ก์ฑ์ ํด๊ฒฐํ๋ฉด CSS ํ์ผ์ ์๋๋ฅผ ๋์ผ ์ ์์ต๋๋ค. (๋ธ๋ผ์ฐ์ ๊ฐ ๋ ๋นจ๋ฆฌ ์ฝ์ด ๋ค์ด๊ธฐ ๋๋ฌธ์ด์ฃ .)
์ด๋ป๊ฒ:
CSS ์ ์ฒ๋ฆฌ๊ธฐ๋ฅผ ์ฌ์ฉํด CSS๋ฅผ ์กฐ์งํด์ผ ํฉ๋๋ค. ์์ ๋์ด๋ ์ผ๋ถ ์จ๋ผ์ธ ํด์ด ์ฝ๋๋ฅผ ๋ถ์ํ๊ณ ๋ฐ๋ก ์ก๋๋ฐ ๋์์ด ๋ ์๋ ์์ต๋๋ค.
-
์นํฐํธ ํฌ๋งท: ์น ํ๋ก์ ํธ ๋๋ ์ดํ๋ฆฌ์ผ์ด์ ์์ WOFF2๋ฅผ ์ฌ์ฉํ์ธ์.
์:
๊ตฌ๊ธ์ ๋ฐ๋ฅด๋ฉด, WOFF 2.0 ์น ํฐํธ ์์ถ ํฌ๋งท์ WOFF 1.0๋ณด๋ค ํ๊ท 30% ๋ ๋ง์ด ์ฐ์ ๋๋ค. TTF์ WOFF 2.0, WOFF 1.0์ ๋์ฒด์ ๋ก ์ฌ์ฉํ๋ ๊ฒ์ด ์ข์ต๋๋ค.
์ด๋ป๊ฒ:
์๋ก์ด ํฐํธ๋ฅผ ๊ตฌ๋งคํ๊ธฐ ์ ์ ์ ๊ณต์๊ฐ WOFF2 ํฌ๋งท์ ์ ๊ณตํ๋์ง ์ฒดํฌํ์ธ์. ๋ง์ฝ ๋ฌด๋ฃ ํฐํธ๋ฅผ ์ฌ์ฉํ๋ค๋ฉด, Font Squirrel์ ํตํด ํ์ํ ํฌ๋งท์ ์์ฑํ ์ ์์ต๋๋ค.
-
ํฐํธ๋ฅผ ๋ ๋นจ๋ฆฌ ๋ก๋ํ๊ธฐ ์ํด
preconnect
๋ฅผ ์ฌ์ฉ:<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
์:
์น ์ฌ์ดํธ์ ์ ์ํ๋ฉด, ๋๋ฐ์ด์ค๋ ์ฌ์ดํธ์ ์์น์ ์ฐ๊ฒฐํด์ผ ํ๋ ์๋ฒ๋ฅผ ์ฐพ์์ผ ํฉ๋๋ค. ๋ธ๋ผ์ฐ์ ๋ DNS ์๋ฒ๋ฅผ ์ฐพ๊ณ , ๋ฆฌ์์ค (ํฐํธ, CSS ํ์ผ...) ์์ง์ด ๋๋๊ธฐ ์ , ์กฐํ๊ฐ ์๋ฃ๋ ๋๊น์ง ๋๊ธฐํด์ผ ํฉ๋๋ค. ์ด๋ prefetches์ preconnects๋ ๋ธ๋ผ์ฐ์ ๊ฐ DNS ์ ๋ณด๋ฅผ ์ฐพ๊ณ ํฐํธ ํ์ผ์ ํธ์คํ ํ๋ ์๋ฒ์ ๋ํ TCP ์ฐ๊ฒฐ์ ํ์ฉํฉ๋๋ค. ์ด๋ ๊ฒ ํ๋ฉด ๋ธ๋ผ์ฐ์ ๊ฐ ํฐํธ ์ ๋ณด์ ์๋ฒ์ ์์ฒญํด์ผ ํ๋ ํฐํธ ํ์ผ์ด ๋ด๊ธด css ํ์ผ์ ํ์ฑํ ๋ ๋ฏธ๋ฆฌ DNS ์ ๋ณด๋ฅผ ํ์ธํ๊ณ , ์ปค๋ฅ์ ํ์ ์๋ ์๋ฒ์ ๋ํ ๊ฐ๋ฐฉํ ์ฐ๊ฒฐ์ ์ค๋นํจ์ผ๋ก์จ ์ฑ๋ฅ์ ๋์ผ ์ ์์ต๋๋ค.
์ด๋ป๊ฒ:
โ ์นํฐํธ๋ฅผ ์ฌ์ ์์งํ๊ธฐ ์ ์, ์น์ฌ์ดํธ๋ฅผ ํ๊ฐํ๊ธฐ ์ํด ์น ํ์ด์ง ํ ์คํธ๋ฅผ ์ฌ์ฉํ์ธ์.
โ teal colored DNS๋ฅผ ์ฐพ๊ณ ์์ฒญ ์ค์ธ ํธ์คํธ๋ฅผ ํ์ธํ์ธ์.
โ<head>
์ ๋ ์นํฐํธ๋ฅผ ์ฌ์ ์์งํ๊ณ ํจ๊ป ์ฌ์ ์์งํ ํธ์คํธ๋ค์์ ์ถ๊ฐํ์ธ์. -
์น ํฐํธ ํฌ๊ธฐ: ์นํฐํธ ํฌ๊ธฐ๊ฐ 300kb๋ฅผ ๋์ง ์๋๋ก ํ์ธ์. (๋ชจ๋ ํ์ ์์ ํฌํจ)
- ํ๋์ ๋๋ ๋ณด์ด์ง ์๋ ํ ์คํธ ๋ฐฉ์ง: ์นํฐํธ๊ฐ ๋ก๋๋ ๋๊น์ง ํฌ๋ช ํ ํ ์คํธ๋ฅผ ์ฌ์ฉํ์ง ๋ง์ธ์.
-
๐ Image Bytes in 2018
-
์ด๋ฏธ์ง ์ต์ ํ: ์ด๋ฏธ์ง๋ ์ต์ ํ๋์ด์ผ ํ๋ฉฐ, ์ต์ข ์ฌ์ฉ์์๊ฒ ์ํฅ์ ๋ฏธ์น์ง ์๋ ์ ์์ ์์ถ๋์ด์ผ ํฉ๋๋ค.
์:
์์ถ๋ ์ด๋ฏธ์ง๋ ๋ธ๋ผ์ฐ์ ์์ ๋ ๋นจ๋ฆฌ ๋ก๋๋๊ณ , ๋ณด๋ค ์ ์ ๋ฐ์ดํฐ๋ฅผ ์๋นํฉ๋๋ค.
์ด๋ป๊ฒ:
โ ๊ฐ๋ฅํ๋ค๋ฉด CSS3 ํจ๊ณผ๋ฅผ ์ฌ์ฉํ์ธ์. (์์ ์ด๋ฏธ์ง ๋์ )
โ ๊ฐ๋ฅํ๋ฉด, ์ด๋ฏธ์ง์ ์ธ์ฝ๋ฉ๋ ํ ์คํธ ๋์ ํฐํธ๋ฅผ ์ฌ์ฉํ์ธ์.
โ SVG๋ฅผ ์ฌ์ฉํ์ธ์.
โ ํด์ ์ฌ์ฉํ๊ณ ์์ถ ๋ ๋ฒจ์ 85 ๋ฏธ๋ง์ผ๋ก ํ์ธ์.- ๐ Image Optimization | Web Fundamentals | Google Developers
- ๐ TinyJPG โ Compress JPEG images intelligently
- ๐ Kraken.io - Online Image Optimizer
- ๐ Compressor.io - optimize and compress JPEG photos and PNG images
- ๐ Cloudinary - Image Analysis Tool
- ๐ SVGOMG - Optimize SVG vector graphics files
-
์ด๋ฏธ์ง ํ์: ์ ์ ํ ์ด๋ฏธ์ง ํ์์ ์ ํํ์ธ์.
์:
์น ์ฌ์ดํธ๋ฅผ ๋๋ฆฌ๊ฒ ๋ง๋ค์ง ์๋ ์ด๋ฏธ์ง ํ์์ ์ฌ์ฉํ์ธ์.
์ด๋ป๊ฒ:
โ Lighthouse๋ฅผ ์ฌ์ฉํด ์ด๋ฏธ์ง๊ฐ ์ต์ข ์ ์ผ๋ก ์ฐจ์ธ๋ ํฌ๋งท(JPEG 2000m JPEG XR ๋๋ WebP)์ ์ฌ์ฉํ ์ ์๋์ง ํ์ธํ์ธ์.
โ ๋ค๋ฅธ ํฌ๋งท์ ๋น๊ตํ์ธ์. ์ด๋จ ๋๋ PNG8์ ์ฌ์ฉํ๋ ๊ฒ์ด PNG16์ ์ฌ์ฉํ๋ ๊ฒ๋ณด๋ค ๋ซ๊ณ , ์ด๋จ ๋๋ ๊ทธ๋ ์ง ์์ต๋๋ค.
-
๋ฒกํฐ ์ด๋ฏธ์ง vs ๋์คํฐ/๋นํธ๋งต: ๋นํธ๋งต ์ด๋ฏธ์ง๋ณด๋ค๋ ๋ฒกํฐ ์ด๋ฏธ์ง๋ฅผ ์ฌ์ฉํ์ธ์. (๊ฐ๋ฅํ๋ค๋ฉด)
์:
๋ฒกํฐ ์ด๋ฏธ์ง (SVG)๋ ๋ค๋ฅธ ์ด๋ฏธ์ง๋ณด๋ค ์๊ณ , SVG๋ ๋ฐ์์ฑ์ด ๋ฐ์ด๋๋ฉฐ ์๋ฒฝํ๊ฒ ํฌ๊ธฐ๊ฐ ๋ณํ ์ ์์ต๋๋ค. ๋ฒกํฐ ์ด๋ฏธ์ง๋ CSS์ ์ํด ์์ ๋๊ฑฐ๋ ์์ง์ผ ์ ์์ต๋๋ค.
-
์ด๋ฏธ์ง ํฌ๊ธฐ: ์ต์ข ์ ์ผ๋ก ๋ํ๋๋ ์ด๋ฏธ์ง ํฌ๊ธฐ๋ฅผ ์๋ค๋ฉด
<img>
์width
์height
์์ฑ์ ๋ช ์ํ์ธ์.์:
๋์ด์ ๋๋น๊ฐ ์ค์ ๋์ด ์์ผ๋ฉด ํ์ด์ง๊ฐ ๋ก๋๋์ ๋ ์ด๋ฏธ์ง๊ฐ ํ์๋กํ๋ ๊ณต๊ฐ์ด ์์ฝ๋ฉ๋๋ค. ํ์ง๋ง, ์ด ์์ฑ์ด ์๋ค๋ฉด, ๋ธ๋ผ์ฐ์ ๋ ์ด๋ฏธ์ง์ ํฌ๊ธฐ๋ฅผ ์ ์ ์๊ณ , ์ ์ ํ ๊ณต๊ฐ์ ์์ฝํด ๋ ์ ์์ต๋๋ค. ๊ทธ๋ฌ๋ฉด ํ์ด์ง๋ฅผ ๋ก๋ฉํ๋ ์ค์ ๋ ์ด์์์ด ๋ณํ๋ ํ์์ด ๋ฐ์ํฉ๋๋ค. (์ด๋ฏธ์ง๋ฅผ ๋ก๋ํ๋ ๋์)
-
Base64 ์ด๋ฏธ์ง ์ฌ์ฉ ์ง์: base64๋ฅผ ํตํด ๊ฒฐ๊ณผ์ ์ผ๋ก ์์ ์ด๋ฏธ์ง๋ฅผ ์ป์ ์ ์์ง๋ง, ์ด๊ฒ์ด ์ต๊ณ ์ ๋ฐฉ๋ฒ์ ์๋๋๋ค.
-
๋ ์ด์ง ๋ก๋ฉ: ์ด๋ฏธ์ง๋ฅผ ๋ ์ด์ง ๋ก๋ฉ์ํค์ธ์. (noscript ํด๋ฐฑ์ด ์ธ์ ๋ ์ ๊ณต๋ฉ๋๋ค.)
์:
์ด๋ ๊ฒ ํ๋ฉด ํ์ฌ ํ์ด์ง์ ๋ฐ์ ์๊ฐ์ ๊ฐ์ ํ๊ณ ์ฌ์ฉ์์๊ฒ ํ์ํ์ง ์์ ์ด๋ฏธ์ง๋ฅผ ๋ก๋ฉํ์ง ์์ ์ ์์ต๋๋ค.
์ด๋ป๊ฒ:
โ Lighthouse๋ฅผ ์ฌ์ฉํด ์ผ๋ง๋ ๋ง์ ์ด๋ฏธ์ง๊ฐ ์คํ์คํฌ๋ฆฐ๋๋ ์ง ํ์ธํ์ธ์.
โ ์ด๋ฏธ์ง๋ฅผ ๋ ์ด์ง ๋ก๋์์ผ์ฃผ๋ ์๋ฐ์คํฌ๋ฆฝํธ ํ๋ฌ๊ทธ์ธ์ ์ฌ์ฉํ์ธ์. -
๋ฐ์ํ ์ด๋ฏธ์ง: ๋์คํ๋ ์ด ํฌ๊ธฐ์ ๋ง๋ ์ด๋ฏธ์ง๋ฅผ ์ฌ์ฉํ์ธ์.
์:
์์ ๋๋ฐ์ด์ค์์๋ ๋ทฐํฌํธ๋ณด๋ค ํฐ ์ด๋ฏธ์ง๊ฐ ํ์ํ์ง ์์ต๋๋ค. ์๋ก ๋ค๋ฅธ ํฌ๊ธฐ์ ์ด๋ฏธ์ง๋ฅผ ์ฌ๋ฌ ๋ฒ์ ์ผ๋ก ์ ๊ณตํ๋ ๊ฒ์ ์ถ์ฒํฉ๋๋ค.
์ด๋ป๊ฒ:
โ ๋๋ฐ์ด์ค์ ๋ฐ๋ผ ๋ค๋ฅธ ํฌ๊ธฐ์ ์ด๋ฏธ์ง๋ฅผ ๋ง๋์ธ์.
โsrcset
๊ณผpicture
๋ฅผ ์ฌ์ฉํด ๊ฐ ์ด๋ฏธ์ง์ ์ฌ๋ฌ ๋ฒ์ ์ ์ ๊ณตํ์ธ์.
-
JS ์์ถ: CSS ํ์ผ์ ์์ถํ๊ณ , ์ต์ข ํ์ผ์์ ์ฃผ์, ๊ณต๋ฐฑ, ์ค๋ฐ๊ฟ์ ์ ๊ฑฐํฉ๋๋ค. (HTTP/2์์๋ ์ฌ์ ํ ์ ํจํฉ๋๋ค.)
์:
๋ถํ์ํ ๊ณต๋ฐฑ, ์ฃผ์, ๊ฐํ์ ์ ๊ฑฐํ๋ฉด ์๋ฐ์คํฌ๋ฆฝํธ ํ์ผ์ ํฌ๊ธฐ๋ฅผ ์ค์ด๊ณ ํ์ด์ง์ ๋ก๋ฉ ์๋๋ฅผ ๋์ผ ์ ์์ต๋๋ค.๊ทธ๋ฆฌ๊ณ ์ฌ์ฉ์์ ๋ค์ด๋ก๋ ์๊ฐ์ ์ค์ผ ์ ์์ต๋๋ค.
์ด๋ป๊ฒ:
๊ฐ๋ฐ์ด๋ ๋น๋ ์ค, ๋๋ ๊ทธ ์ ์ ํ์ผ์ ์๋์ผ๋ก ์์ถํด์ฃผ๋ ํด์ ์ฌ์ฉํ์ธ์.
-
JavaScript ์์ ๋์ง ์๊ธฐ: (์น์ฌ์ดํธ์์๋ง ์ ํจํฉ๋๋ค.) ์ฌ๋ฌ ์๋ฐ์คํฌ๋ฆฝํธ ์ฝ๋๋ฅผ ๋ฐ๋ ์ค๊ฐ์ ๋์ง ๋ง์ธ์. ์๋ฐ์คํฌ๋ฆฝํธ ์ฝ๋๋ฅผ ๋ค์ ๊ทธ๋ฃนํํด ์ธ๋ถ ํ์ผ์ด๋
<head>
๋๋ ํ์ด์ง์ ๋ง์ง๋ง(</body>
์ด์ )์ ๋๋๋ก ํ์ธ์.์:
์๋ฐ์คํธ๋ฆฝํธ ์๋ฒ ๋๋ ์ฝ๋๋ฅผ
<body>
์ ๋๋ฉด DOM์ด ๊ตฌ์ฑ๋๋ ๊ณผ์ ์์ ์ฝ๋๊ฐ ๋ก๋๋๊ธฐ ๋๋ฌธ์ ํ์ด์ง ์๋๋ฅผ ๋จ์ด๋จ๋ฆด ์ ์์ต๋๋ค. ๊ฐ์ฅ ์ข์ ์ต์ ์ ์ธ๋ถ ํ์ผ์async
๋๋defer
์์ฑ๊ณผ ํจ๊ป ์ฌ์ฉํ์ฌ DOM ๋ก๋ฉ์ ๋ง์ง ์๋๋กํ๋ ๊ฒ์ ๋๋ค. ๋ ๋ค๋ฅธ ์ต์ ์ ์คํฌ๋ฆฝํธ๋ฅผ<head>
์ ๋๋ ๊ฒ์ ๋๋ค. ๋๋ถ๋ถ์ ์๊ฐ ๋ถ์ ์ฝ๋ ๋๋ DOM์ด ์ฃผ์ ์ฒ๋ฆฌ๋ถ๋ถ์ ๋๋ฌํ๊ธฐ ์ ์ ๋ก๋๋์ด์ผ ํ๋ ์์ ์คํฌ๋ฆฝํธ๋ฅผ ๋ ์ ์์ต๋๋ค.์ด๋ป๊ฒ:
๋ชจ๋ ํ์ผ์ด
async
๋๋defer
๋ฅผ ํตํด ๋ก๋๋๋์ง ํ์ธํ์ธ์. ๊ทธ๋ฆฌ๊ณ<head>
์ ์ด๋ค ์ฝ๋๋ฅผ ๋์ง ํ๋ช ํ๊ฒ ๊ฒฐ์ ํ์ธ์. -
Non-blocking ์๋ฐ์คํฌ๋ฆฝํธ: ์๋ฐ์คํฌ๋ฆฝํธ ํ์ผ์ ๋น๋๊ธฐ์ ์ผ๋ก ๋ก๋ํ๊ธฐ ์ํด
async
๋ฅผ ์ฌ์ฉํ๊ฑฐ๋ ์ง์ฐ์ํค๊ธฐ ์ํดdefer
์์ฑ์ ์ฌ์ฉํ์ธ์.<!-- Defer Attribute --> <script defer src="foo.js"> <!-- Async Attribute --> <script async src="foo.js">
์:
์๋ฐ์คํฌ๋ฆฝํธ๋ HTML ๋ฌธ์์ ํ์ฑ์ ์ฐจ๋จํ๊ธฐ ๋๋ฌธ์, ํ์๋
<script>
ํ๊ทธ์ ๋๋ฌํ ๋ (ํนํ<head>
์์ ์์ ๋) ํ์ฑ์ ๋ฉ์ถ๊ณ ์คํฌ๋ฆฝํธ๋ฅผ ์คํํฉ๋๋ค. ์คํฌ๋ฆฝํธ๋ฅผ ํ์ด์ง์ ์๋จ์ ๋๋ ๊ฒฝ์ฐasync
๋๋defer
๋ฅผ ์ฌ์ฉํ๋ ๊ฒ์ด ์ ๊ทน ๊ถ์ฅ๋ฉ๋๋ค๋ง, ๋ง์ฝ</body>
ํ๊ทธ ๋ฐ๋ก ์์ ์คํฌ๋ฆฝํธ๋ฅผ ๋๋ ๊ฒฝ์ฐ ์ค์๋๊ฐ ๋จ์ด์ง๋๋ค. ํ์ง๋ง ์ธ์ ๋ ์ด ์์ฑ์ ์ฌ์ฉํ์ฌ ์ฑ๋ฅ ์ด์๋ฅผ ํผํ๋ ๊ฒ์ ์ข์ ์ต๊ด์ ๋๋ค.์ด๋ป๊ฒ:
โ
async
(๋ง์ฝ ์คํฌ๋ฆฝํธ๊ฐ ๋ค๋ฅธ ์คํฌ๋ฆฝํธ์ ์์กดํ์ง ์์ ๊ฒฝ์ฐ) ๋๋defer
(๋ง์ฝ ์คํฌ๋ฆฝํธ๊ฐ ๋น๋๊ธฐ ์คํฌ๋ฆฝํธ์ ์์กดํ ๊ฒฝ์ฐ) ์์ฑ์ ์คํฌ๋ฆฝํธ ํ๊ทธ์ ์ถ๊ฐํ์ธ์.
โ ๋ง์ฝ ์คํฌ๋ฆฝํธ๊ฐ ์๋ค๋ฉด, ๋น๋๊ธฐ ์คํฌ๋ฆฝํธ ์์ ์ธ๋ผ์ธ ์คํฌ๋ฆฝํธ๋ฅผ ๋ ์๋ ์์ต๋๋ค. -
์ต์ ํ์ JS ๋ผ์ด๋ธ๋ฌ๋ฆฌ ์ ๋ฐ์ดํธ: ํ๋ก์ ํธ์๋ ๋ผ์ด๋ธ๋ฌ๋ฆฌ๊ฐ ํ์ํ๋ฉฐ (๋จ์ํ ๊ธฐ๋ฅ์ ์ํด ๋ฐ๋๋ผ ์๋ฐ์คํฌ๋ฆฝํธ๋ฅผ ์งํฅํ์ธ์.), ์ด๋ค์ ์ต์ ๋ฒ์ ์ผ๋ก ์ ๋ฐ์ดํธํ๊ณ ๋ถํ์ํ ๋ฉ์๋๋ค์ด ๋น์ ์ ์๋ฐ์คํฌ๋ฆฝํธ ์ฝ๋๋ฅผ ์๋ํ์ง ์๋๋ก ํ์ธ์.
์:
๋๋ถ๋ถ์ ๊ฒฝ์ฐ, ์๋ก์ด ๋ฒ์ ์ ์ต์ ํ๋๊ณ ๋ณด์ ํจ์น๊ฐ ์ ์ฉ๋ฉ๋๋ค. ํ์ด์ง์ ์๋๋ฅผ ๋์ด๊ธฐ ์ํด ์ฝ๋๋ฅผ ์ต์ ํํด์ผ ํ๋ฉฐ, ์น์ฌ์ดํธ๋ ์ฑ์ ๋๋ฆฌ๊ฒ ๋ง๋ค์ง ์๊ธฐ ์ํด ์ค๋๋ ํ๋ฌ๊ทธ์ธ์ ์ฌ์ฉํ์ง ์๋์ง ํ์ธํด์ผ ํฉ๋๋ค.
์ด๋ป๊ฒ:
๋ง์ฝ ํ๋ก์ ํธ๊ฐ NPM ํจํค์ง๋ค์ ์ฌ์ฉํ๋ค๋ฉด, npm-check๊ฐ ๋ผ์ด๋ธ๋ฌ๋ฆฌ๋ฅผ ์ ๊ทธ๋ ์ด๋ / ์ ๋ฐ์ดํธํ๋ ๋ฐ ์ ์ฉํ ๊ฒ์ ๋๋ค.
-
๋ํ๋์ ํฌ๊ธฐ ์ ํ: ์ธ๋ถ ๋ผ์ด๋ธ๋ฌ๋ฆฌ๋ฅผ ํ๋ช ํ๊ฒ ์ฌ์ฉํ์ธ์. ๋๋ถ๋ถ์ ๊ฒฝ์ฐ, ๋๊ฐ์ ๊ธฐ๋ฅ์ ํ์ง๋ง ๋ ๊ฐ๋ฒผ์ด ๋ผ์ด๋ธ๋ฌ๋ฆฌ๋ฅผ ์ฐพ์ ์ ์์ต๋๋ค.
์:
745 000 ํจํค์ง ์ค ์ฌ์ฉํ๋ ค๋ ํจํค์ง ํ๋๋ฅผ npm์์ ์ฐพ์ ์ ์์ต๋๋ค. ํ์ง๋ง ๊ฐ์ฅ ์ข์ ํจํค์ง๋ฅผ ๊ณจ๋ผ์ผ ํฉ๋๋ค. ์๋ฅผ ๋ค์ด, MomentJS๋ ๊ต์ฅํ ๋ผ์ด๋ธ๋ฌ๋ฆฌ์ง๋ง, ๋ง์ ๋ฉ์๋๋ฅผ ์ฌ์ฉํ์ง ์์ ๊ฒ์ ๋๋ค. Day.js๊ฐ ๋ง๋ค์ด์ง ์ด์ ์ฃ . Day.js 2kB vs Moment 16.4kB gz ์ ๋๋ค.
์ด๋ป๊ฒ:
ํญ์ ๋ ๊ฐ๋ณ๊ณ ์ข์ ๋ผ์ด๋ธ๋ฌ๋ฆฌ๋ฅผ ์ฐพ๊ธฐ ์ํด ๋น๊ตํ์ธ์. npm trends์ ๊ฐ์ ํด์ ์ด์ฉํด NPM ๋ค์ด๋ก๋ ์๋ฅผ ๋น๊ตํ๊ฑฐ๋ Bundlephobia๋ฅผ ํตํด ๋ํ๋์์ ํฌ๊ธฐ๋ฅผ ์ ์ ์์ต๋๋ค.
-
JavaScript ํ๋กํ์ผ๋ง: ์๋ฐ์คํฌ๋ฆฝํธ ํ์ผ์ ์ฑ๋ฅ ๋ฌธ์ ๋ฅผ ์ฒดํฌํ์ธ์. (CSS๋ ๊ฐ์ด ์ฒดํฌํ์ธ์.)
์:
์๋ฐ์คํฌ๋ฆฝํธ ๋ณต์ก๋๋ ๋ฐํ์ ์ฑ๋ฅ์ ๋จ์ด๋จ๋ฆด ์ ์์ต๋๋ค. ์ํ์ฑ์ด ์๋ ์ด์๋ฅผ ํ์ธํ๋ ๊ฒ์ ๋งค๋๋ฌ์ด ์ฌ์ฉ์ ๊ฒฝํ์ ์ ๊ณตํ๋ ๋ฐ ํ์์ ์ ๋๋ค.
์ด๋ป๊ฒ:
ํฌ๋กฌ ๊ฐ๋ฐ์ ๋๊ตฌ์ ํ์๋ผ์ธ ํด์ ์ด์ฉํด ์คํฌ๋ฆฝํธ ์ด๋ฒคํธ๋ฅผ ํ ์คํธํ๊ณ ๋๋ฌด ์ค๋ ์๊ฐ์ ์๋ชจํ๋ ์ด๋ฒคํธ๋ฅผ ์ฐพ์๋ด์ธ์.
- ๐ Speed Up JavaScript Execution ย |ย Tools for Web Developers ย |ย Google Developers
- ๐ JavaScript Profiling With The Chrome Developer Tools โ Smashing Magazine
- ๐ How to Record Heap Snapshots ย |ย Tools for Web Developers ย |ย Google Developers
- ๐ Chapter 22 - Profiling the Frontend - Blackfire
-
์นํ์ด์ง ํฌ๊ธฐ < 1500 KB: (์ด์์ ์ธ ํฌ๊ธฐ < 500 KB) ํ์ด์ง์ ํฌ๊ธฐ + ๋ฆฌ์์ค๋ฅผ ์ต๋ํ ์ค์ด์ธ์
์:
500 KB ๋ฏธ๋ง์ด ์ด์์ ์ด์ง๋ง ์น์ ์ํ์ ๋ฐ๋ผ ํฌ๋ก๋ฐ์ดํธ์ ์ค์๊ฐ์ด 1500 KB ์ ๋๋ก ํ์๋ฉ๋๋ค. (๋ชจ๋ฐ์ผ์์๋ ๊ทธ๋ ์ต๋๋ค.) ์ต์์ ์ฌ์ฉ์ ๊ฒฝํ์ ์ ๊ณตํ๋ ค๋ฉด ํ๊ฒ ์ฌ์ฉ์, ๋คํธ์ํฌ ์ฐ๊ฒฐ, ๋๋ฐ์ด์ค์ ๋ฐ๋ผ ์ด ํฌ๋ก๋ฐ์ดํธ๋ฅผ ์ต๋ํ ์ค์ฌ์ผ ํฉ๋๋ค.
์ด๋ป๊ฒ:
ํ๋ก ํธ์๋ ์ฑ๋ฅ ์ฒดํฌ๋ฆฌ์คํธ์ ๋ชจ๋ ๊ท์น๋ค์ ๋ฆฌ์์ค์ ์ฝ๋๋ฅผ ์ต๋ํ ์ค์ด๋๋ก ํ๊ณ ์์ต๋๋ค.
-
ํ์ด์ง ๋ก๋ ์๊ฐ < 3์ด: ํ์ด์ง ๋ก๋ ์๊ฐ์ ์ต๋ํ ์ค์ฌ ์ฌ์ฉ์์๊ฒ ์ฝํ ์ธ ๊ฐ ๋น ๋ฅด๊ฒ ์ ์ก๋๋๋ก ํ์ธ์.
์:
์น์ฌ์ดํธ๋ ์ฑ์ด ๋นจ๋ผ์ง์๋ก ๋ฐ์ด์ค ์ฆ๊ฐ ๊ฐ๋ฅ์ฑ์ด ์ค์ด๋ญ๋๋ค. ํํธ ์ฌ์ฉ์๋ ๋ฏธ๋์ ํด๋ผ์ด์ธํธ๋ฅผ ์์ ๊ฐ๋ฅ์ฑ๋ ์ค์ด๋ญ๋๋ค. ์ด ์ฃผ์ ์ ๋ํ ๋ง์ ์ฐ๊ตฌ๊ฐ ์ด๋ฅผ ์ฆ๋ช ํฉ๋๋ค.
์ด๋ป๊ฒ:
Page Speed Insight ๋๋ WebPageTest์ ๊ฐ์ ์จ๋ผ์ธ ํด์ ์ด์ฉํด ๋ฌด์์ด ํ์ด์ง๋ฅผ ๋๋ฆฌ๊ฒ ๋ง๋๋์ง ๋ถ์ํ๊ณ , ํ๋ก ํธ์๋ ์ฒดํฌ ๋ฆฌ์คํธ๋ฅผ ์ด์ฉํด ๋ก๋ ์๊ฐ์ ๊ฐ์ ํ์ธ์.
-
์ฒซ ๋ฒ์งธ ๋ฐ์ดํธ ์๊ฐ(TTFB) < 1.3์ด: ๋ธ๋ผ์ฐ์ ๊ฐ ๋ฐ์ดํฐ๋ฅผ ๋ฐ๊ธฐ ์ ๊น์ง ๋๊ธฐํ๋ ์๊ฐ์ ์ต๋ํ ์ค์ด์ธ์.
-
์ฟ ํค ํฌ๊ธฐ: ๋ง์ฝ ์ฟ ํค๋ฅผ ์ฌ์ฉํ๋ค๋ฉด ๊ฐ ์ฟ ํค๊ฐ 4096 ๋ฐ์ดํธ๋ฅผ ๋์ด์๋ ์ ๋๋ฉฐ, ๋๋ฉ์ธ ๋ค์์ด 20๊ฐ ์ด์์ ์ฟ ํค๋ฅผ ๊ฐ์ ธ์๋ ์ ๋ฉ๋๋ค.
์:
์ฟ ํค๋ HTTP ํค๋์์ ์น ์๋ฒ์ ๋ธ๋ผ์ฐ์ ์ฌ์ด์ ๊ตํ๋ฉ๋๋ค. ์ฌ์ฉ์์ ์๋ต ์๊ฐ์ ๋ฏธ์น๋ ์ํฅ์ ์ต์ํํ๊ธฐ ์ํด์๋ ์ฟ ํค์ ํฌ๊ธฐ๋ฅผ ์ต๋ํ ์ค์ฌ์ผ ํฉ๋๋ค.
์ด๋ป๊ฒ:
๋ถํ์ํ ์ฟ ํค๋ฅผ ์ ๊ฑฐํ์ธ์.
- HTTP ์์ฒญ ์ต์ํ: ํญ์ ๋ชจ๋ ํ์ผ์ ์์ฒญ์ด ์น์ฌ์ดํธ๋ ์ดํ๋ฆฌ์ผ์ด์ ์ ํ์์ ์ธ์ง ํ์ธํ์ธ์.
- CDN์ ํตํ ์ด์ ์ ๊ณต: ์ ์ธ๊ณ์ ์ฝํ ์ธ ๋ฅผ ๋ ๋น ๋ฅด๊ฒ ์ ๊ณตํ๊ธฐ ์ํด CDN์ ์ฌ์ฉํ์ธ์.
- ๐ 10 Tips to Optimize CDN Performance - CDN Planet
- ๐ HTTP Caching ย |ย Web Fundamentals ย |ย Google Developers
-
๋์ผํ ํ๋กํ ์ฝ์์ ํ์ผ ์ ๊ณต: ์น ์ฌ์ดํธ์์ HTTPS๋ฅผ ์ฌ์ฉํ์ง ์๋๋กํ๊ณ HTTP๋ฅผ ์ด์ฉํ๋ ์์ค์์ ํ์ผ์ ๊ฐ์ ธ์ค์ธ์.
-
์ฐ๊ฒฐ ๊ฐ๋ฅํ ํ์ผ ์ ๊ณต: ์ฐ๊ฒฐ ๋ถ๊ฐ๋ฅํ ํ์ผ(404)์ ์์ฒญํ์ง ๋ง์ธ์.
- ์ฌ๋ฐ๋ฅธ HTTP ์บ์ ํค๋ ์ค์ : ๋ธ๋ผ์ฐ์ ์ ์๋ฒ ์ฌ์ด ๋น์ฉ์ด ํฐ ์๋ณต์ ํผํ๋๋ก HTTP ํค๋๋ฅผ ์ค์ ํ์ธ์.
- ๐ Optimizing Performance - React
- ๐ React image manipulation | Cloudinary
- ๐ Debugging React performance with React 16 and Chrome Devtools.
- ๐ 19 Tips to Speed Up WordPress Performance (Updated)
- ๐ Speed Up Your WordPress - How to Save Images Optimized for Web
ํ๋ก ํธ ์๋ ์ฑ๋ฅ ์ฒดํฌ๋ฆฌ์คํธ๊ฐ ๋ค๋ฅธ ์ธ์ด๋ก ์ฝํ๊ธธ ๋ฐ๋๋๋ค! ์ปจํธ๋ฆฌ๋ทฐ์ ์ ๋ง์ค์ด์ง ๋ง์์ฃผ์ธ์!
- ๐ต๐น Portuguese: fernandofawkes/Front-End-Performance-Checklist
- ๐จ๐ณ Chinese: JohnsenZhou/Front-End-Performance-Checklist
- ๐ท๐บ Russian: lex111/Front-End-Performance-Checklist
- ๐ซ๐ท French: WilliamDASILVA/Front-End-Performance-Checklist
์ด์๋ฅผ ์ด๊ฑฐ๋ ํ ๋ฆฌํ์คํธ๋ฅผ ๋ณด๋ด ๋ณ๊ฒฝ ์ฌํญ์ด๋ ์ถ๊ฐ์ ์ ์ ์ํ์ธ์.
์ง๋ฌธ์ด๋ ์ ์์ด ์๋ค๋ฉด Gitter๋ ํธ์ํฐ ์ฌ์ฉ์ ๋ง์ค์ด์ง ๋ง์ธ์:
Build with โค๏ธ by David Dias at @influitive ๐จ๐ฆ
This project exists thanks to all the people who contribute. [Contribute].
Thank you to all our backers! ๐ [Become a backer]
Support this project by becoming a sponsor. Your logo will show up here with a link to your website. [Become a sponsor]
All icons are provided by Icons8