μΉ μ± λ§€λνμ€νΈμ λν ν¬κ΄μ μΈ μ΄ν΄λ₯Ό ν΅ν΄ νλ‘κ·Έλ μλΈ μΉ μ±(PWA)μ μ μ¬λ ₯μ μ΅λν λ°ννμΈμ. μ΅μ μ μ¬μ©μ κ²½νκ³Ό κ²μ κ°λ₯μ±μ μν΄ PWAλ₯Ό ꡬμ±νλ λ°©λ²μ μμ보μΈμ.
μΉ μ± λ§€λνμ€νΈ: νλ‘κ·Έλ μλΈ μΉ μ± κ΅¬μ±μ μν μλ΄μ
μΉ μ± λ§€λνμ€νΈλ μΉ μ ν리μΌμ΄μ μ λν μ 보λ₯Ό λΈλΌμ°μ μ μ΄μ 체μ μ μ 곡νλ JSON νμΌμ λλ€. μ΄ μ 보λ μ±μ΄ μ¬μ©μμ κΈ°κΈ°μ μ€μΉλ λ μ¬μ©λλ©°, νλ‘κ·Έλ μλΈ μΉ μ±(PWA)μΌλ‘μ μ΄λ»κ² 보μ΄κ³ μλνλμ§λ₯Ό μ μν©λλ€. μΉμ¬μ΄νΈλ₯Ό μ€μΉ κ°λ₯ν μ±κ³Ό κ°μ κ²½νμΌλ‘ λ³ννλ μ²μ¬μ§μ΄λΌκ³ μκ°νλ©΄ λ©λλ€. μ ꡬμ±λ λ§€λνμ€νΈλ μ¬μ©μ μ°Έμ¬μ κ²μ κ°λ₯μ±μ λ§€μ° μ€μν©λλ€.
νλ‘κ·Έλ μλΈ μΉ μ±(PWA)μ΄λ 무μμΈκ°μ?
μΉ μ± λ§€λνμ€νΈμ λν΄ μμΈν μμ보기 μ μ PWAκ° λ¬΄μμΈμ§ λ€μ νλ² μ΄ν΄λ³΄κ² μ΅λλ€. PWAλ μ¬μ©μμκ² μ±κ³Ό κ°μ κ²½νμ μ 곡νλ μΉ μ ν리μΌμ΄μ μ λλ€. PWAλ λ€μκ³Ό κ°μ΅λλ€:
- μ λ’°μ±: μλΉμ€ μ컀 λλΆμ μ¦μ λ‘λλκ³ μ€νλΌμΈ λλ μ νμ§ λ€νΈμν¬μμλ μλν©λλ€.
- λΉ λ₯Έ μλ: λΆλλ¬μ΄ μ λλ©μ΄μ κ³Ό λκΉ μλ μ€ν¬λ‘€λ§μΌλ‘ μ¬μ©μ μνΈ μμ©μ λΉ λ₯΄κ² μλ΅ν©λλ€.
- μ°Έμ¬ μ λ: νΈμ μλ¦Ό λ° ν νλ©΄μ μ€μΉν μ μλ κΈ°λ₯κ³Ό κ°μ κΈ°λ₯μΌλ‘ λͺ°μ κ° μλ μ¬μ©μ κ²½νμ μ 곡ν©λλ€.
μΉ μ± λ§€λνμ€νΈμ μν
μΉ μ± λ§€λνμ€νΈλ PWAμ μ΄μμ λλ€. λΈλΌμ°μ κ° λ€μμ μννλ λ° νμν μ 보λ₯Ό μ 곡ν©λλ€:
- PWA μ€μΉ: μ¬μ©μκ° μΉ μ±μ κΈ°κΈ°μ μ€μΉνκ³ ν νλ©΄μ΄λ μ± μ€νκΈ°μ μΆκ°ν μ μλλ‘ ν©λλ€.
- PWA μ¬λ°λ₯΄κ² νμ: μ±μ μ΄λ¦, μμ΄μ½, ν λ§ μμ λ° κΈ°ν μκ°μ μΈ‘λ©΄μ μ μν©λλ€.
- PWA λμ μ μ΄: μ±μ΄ μμλλ λ°©μ(μ: μ 체 νλ©΄ λͺ¨λ λλ λ 립 μ€νν μ°½)κ³Ό μ΄μ 체μ μ ν΅ν©λλ λ°©μμ μ§μ ν©λλ€.
`manifest.json` νμΌ λ§λ€κΈ°
μΉ μ± λ§€λνμ€νΈλ μΌλ°μ μΌλ‘ `manifest.json`μ΄λΌλ JSON νμΌμ λλ€. μΉ μ ν리μΌμ΄μ μ λ£¨νΈ λλ ν 리μ λ°°μΉν΄μΌ ν©λλ€. λ€μμ κΈ°λ³Έ μμμ λλ€:
{
"name": "My Awesome PWA",
"short_name": "Awesome PWA",
"start_url": "/",
"display": "standalone",
"background_color": "#ffffff",
"theme_color": "#000000",
"icons": [
{
"src": "/icons/icon-192x192.png",
"sizes": "192x192",
"type": "image/png"
},
{
"src": "/icons/icon-512x512.png",
"sizes": "512x512",
"type": "image/png"
}
]
}
κ° μμ±μ μμΈν μ΄ν΄λ³΄κ² μ΅λλ€:
`name`
μΉ μ ν리μΌμ΄μ μ μ 체 μ΄λ¦μ λλ€. μ΄ μ΄λ¦μ μ± μ€μΉκ° μ μλ λ μ¬μ©μμκ² νμλλ©° μ± μ€νκΈ°μλ νμλ©λλ€.
μμ:
"name": "Global News App"
`short_name`
μ±μ μ΄λ¦μ μ§§μ λ²μ μΌλ‘, ν νλ©΄μ΄λ μ± μ€νκΈ°μ κ°μ΄ 곡κ°μ΄ μ νλ κ²½μ° μ¬μ©λ©λλ€. κ°κ²°νκ² μ μ§νμΈμ.
μμ:
"short_name": "Global News"
`start_url`
μ±μ΄ μμλ λ λ‘λν΄μΌ νλ URLμ λλ€. μΌλ°μ μΌλ‘ μΉ μ ν리μΌμ΄μ μ ννμ΄μ§μ΄μ§λ§ νΉμ λλ© νμ΄μ§μΌ μλ μμ΅λλ€.
μμ:
"start_url": "/"
μ¬μ©μκ° PWAλ₯Ό μμνλ λ°©μμ μΆμ νκΈ° μν΄ μΏΌλ¦¬ λ§€κ°λ³μκ° μλ URLμ μ¬μ©ν μλ μμ΅λλ€:
"start_url": "/?utm_source=homescreen"
`display`
μ±μ΄ μμλ λ μ΄λ»κ² νμλμ΄μΌ νλμ§λ₯Ό μ μν©λλ€. λͺ κ°μ§ μ΅μ μ΄ μμ΅λλ€:
- `standalone`: μ±μ μ£Όμ νμμ€κ³Ό κ°μ λΈλΌμ°μ UI μμ μμ΄ μ체 μ΅μμ μ°½μΌλ‘ μ΄λ¦½λλ€.
- `fullscreen`: μ±μ μν νμμ€μ‘°μ°¨ μ¨κΈ°κ³ μ 체 νλ©΄μ μ°¨μ§ν©λλ€.
- `minimal-ui`: `standalone`κ³Ό μ μ¬νμ§λ§ λ€λ‘ κ°κΈ° λ²νΌ λ° μλ‘ κ³ μΉ¨ λ²νΌκ³Ό κ°μ μ΅μνμ λΈλΌμ°μ UIλ₯Ό μ 곡ν©λλ€.
- `browser`: μ±μ μΌλ° λΈλΌμ°μ ν λλ μ°½μΌλ‘ μ΄λ¦½λλ€.
κΆμ₯ μ¬ν: `standalone`μ μΌλ°μ μΌλ‘ PWAμ μ νΈλλ μ΅μ μ λλ€.
μμ:
"display": "standalone"
`background_color`
μ±μ΄ μμλ λ μ±μ μ€νλμ νλ©΄ λ°°κ²½μμ λλ€. μ΄λ μ± μμ΄μ½κ³Ό μ± μ½ν μΈ κ°μ μνν μ νμ μ 곡νλ λ° μ€μν©λλ€.
μμ:
"background_color": "#ffffff"
`theme_color`
Androidμ μν νμμ€κ³Ό κ°μ΄ μ± UIλ₯Ό μ€νμΌλ§νλ λ° μ¬μ©λλ ν λ§ μμμ λλ€. μ΄ μμμ μ±μ λΈλλ©κ³Ό μΌμΉν΄μΌ ν©λλ€.
μμ:
"theme_color": "#000000"
`icons`
μ±μ μμ΄μ½μ λνλ΄λ κ°μ²΄ λ°°μ΄μ λλ€. λ€μν μ₯μΉ λ° ν΄μλμμ μ±μ΄ μ 보μ΄λλ‘ μ¬λ¬ ν¬κΈ°μ μμ΄μ½μ μ 곡ν΄μΌ ν©λλ€.
κ° μμ΄μ½μ μμ±:
- `src`: μμ΄μ½ μ΄λ―Έμ§μ URLμ λλ€.
- `sizes`: ν½μ λ¨μμ μμ΄μ½ μΉμ(μ: "192x192")μ λλ€.
- `type`: μμ΄μ½ μ΄λ―Έμ§μ MIME μ ν(μ: "image/png")μ λλ€.
κΆμ₯ μμ΄μ½ ν¬κΈ°:
- 48x48
- 72x72
- 96x96
- 144x144
- 192x192
- 512x512
μμ:
"icons": [
{
"src": "/icons/icon-192x192.png",
"sizes": "192x192",
"type": "image/png"
},
{
"src": "/icons/icon-512x512.png",
"sizes": "512x512",
"type": "image/png"
}
]
μΆκ° λ§€λνμ€νΈ μμ±
μμ μμ±μ΄ κ°μ₯ μΌλ°μ μ΄μ§λ§ μΉ μ± λ§€λνμ€νΈλ PWA ꡬμ±μ μν λ€λ₯Έ λ§μ μ΅μ μ μ§μν©λλ€:
`id`
PWAμ κ³ μ μλ³μμ λλ€. μ΄λ¦μ΄ κ°μ μ¬λ¬ PWAκ° μμ κ²½μ° μΆ©λμ λ°©μ§νλ λ° μ€μν©λλ€.
μμ:
"id": "com.example.myapp"
`scope`
μ±μ νμ λ²μλ₯Ό μ μν©λλ€. μ΄λ μΉμ¬μ΄νΈ λ΄μ μ΄λ€ URLμ΄ PWAμ μΌλΆλ‘ κ°μ£Όλλμ§λ₯Ό κ²°μ ν©λλ€. μ¬μ©μκ° λ²μλ₯Ό λ²μ΄λ κ³³μΌλ‘ μ΄λνλ©΄ μ±μ μΌλ° λΈλΌμ°μ νμμ μ΄λ¦½λλ€.
μμ:
"scope": "/app/"
μ΄ μμμμλ `/app/`μΌλ‘ μμνλ URLλ§ PWAμ μΌλΆλ‘ κ°μ£Όλ©λλ€.
`orientation`
μ±μ μ νΈ νλ©΄ λ°©ν₯μ μ§μ ν©λλ€. μ΅μ μλ `portrait`, `landscape`, `any` λ±μ΄ μμ΅λλ€.
μμ:
"orientation": "portrait"
`related_applications`
κ΄λ ¨ λ€μ΄ν°λΈ μ ν리μΌμ΄μ μ μ μνλ κ°μ²΄ λ°°μ΄μ λλ€. μ΄λ₯Ό ν΅ν΄ PWAλ₯Ό μ€μΉν μ¬μ©μμκ² λ€μ΄ν°λΈ μ±μ ν보ν μ μμ΅λλ€.
μμ:
"related_applications": [
{
"platform": "play",
"id": "com.example.myapp"
}
]
μ΄ μμλ `com.example.myapp` IDλ₯Ό κ°μ§ Google Play μ€ν μ΄μ κ΄λ ¨ λ€μ΄ν°λΈ μ±μ΄ μμμ λνλ λλ€.
`prefer_related_applications`
μ¬μ©μμκ² PWA λμ κ΄λ ¨ λ€μ΄ν°λΈ μ ν리μΌμ΄μ μ μ€μΉνλλ‘ κΆμ₯ν μ§ μ¬λΆλ₯Ό λνλ΄λ λΆλ¦¬μΈ κ°μ λλ€.
μμ:
"prefer_related_applications": true
`categories`
μ±μ μΉ΄ν κ³ λ¦¬λ₯Ό λνλ΄λ λ¬Έμμ΄ λ°°μ΄μ λλ€. μ΄λ₯Ό ν΅ν΄ μ¬μ©μκ° μ± μ€ν μ΄ λλ κ²μ κ²°κ³Όμμ μ±μ μ°Ύλ λ° λμμ΄ λ μ μμ΅λλ€.
μμ:
"categories": ["news", "information"]
`shortcuts`
μ¬μ©μκ° ν νλ©΄μ μ± μμ΄μ½μμ μ‘μΈμ€ν μ μλ λ°λ‘κ°κΈ° λͺ©λ‘μ μ μν©λλ€. μ΄λ₯Ό ν΅ν΄ μ¬μ©μλ μ± λ΄μμ μμ£Ό μ¬μ©νλ μμ μ λΉ λ₯΄κ² μνν μ μμ΅λλ€.
μμ:
"shortcuts": [
{
"name": "Latest News",
"short_name": "News",
"description": "Read the latest news articles",
"url": "/news",
"icons": [{
"src": "/icons/news.png",
"sizes": "192x192",
"type": "image/png"
}]
}
]
λ§€λνμ€νΈλ₯Ό μΉ μ±μ μ°κ²°νκΈ°
`manifest.json` νμΌμ λ§λ νμλ HTMLμ `
` μΉμ μ `` νκ·Έλ₯Ό μΆκ°νμ¬ μΉ μ ν리μΌμ΄μ μ μ°κ²°ν΄μΌ ν©λλ€:
<link rel="manifest" href="/manifest.json">
λ§€λνμ€νΈ μ ν¨μ± κ²μ¬
λ§€λνμ€νΈ νμΌμ΄ μ¬λ°λ₯΄κ² νμμ΄ μ§μ λμκ³ νμν λͺ¨λ μμ±μ ν¬ν¨νκ³ μλμ§ νμΈνκΈ° μν΄ `manifest.json` νμΌμ μ ν¨μ±μ κ²μ¬νλ κ²μ΄ μ€μν©λλ€. λ§€λνμ€νΈ μ ν¨μ±μ κ²μ¬νλ €λ©΄ JSONLintμ κ°μ μ¨λΌμΈ λꡬλ Chrome κ°λ°μ λꡬλ₯Ό μ¬μ©ν μ μμ΅λλ€.
PWA ν μ€νΈ
λ§€λνμ€νΈλ₯Ό λ§λ€κ³ μ°κ²°ν νμλ λ€λ₯Έ λΈλΌμ°μ μ μ₯μΉμμ PWAλ₯Ό ν μ€νΈνμ¬ μμλλ‘ μλνλμ§ νμΈν΄μΌ ν©λλ€. λ§€λνμ€νΈλ₯Ό κ²μ¬νκ³ λ¬Έμ λ₯Ό μ§λ¨νλ €λ©΄ Chrome κ°λ°μ λꡬ(Application -> Manifest)λ₯Ό μ¬μ©νμμμ€.
μΉ μ± λ§€λνμ€νΈ κ΅¬μ± λͺ¨λ² μ¬λ‘
μΉ μ± λ§€λνμ€νΈλ₯Ό ꡬμ±ν λ μΌλμ λμ΄μΌ ν λͺ κ°μ§ λͺ¨λ² μ¬λ‘λ λ€μκ³Ό κ°μ΅λλ€:
- λͺ¨λ νμ μμ± μ 곡: `name`, `short_name`, `start_url`, `display`, `background_color`, `theme_color`, `icons`μ κ°μ νμ μμ±μ λͺ¨λ ν¬ν¨νλμ§ νμΈνμμμ€.
- μ μ ν μμ΄μ½ ν¬κΈ° μ¬μ©: λ€μν μ₯μΉ λ° ν΄μλλ₯Ό μ§μνκΈ° μν΄ μ¬λ¬ ν¬κΈ°μ μμ΄μ½μ μ 곡νμμμ€.
- μ¬λ°λ₯Έ λμ€νλ μ΄ λͺ¨λ μ ν: μ±μ μ¬μ©μ κ²½νμ κ°μ₯ μ ν©ν `display` λͺ¨λλ₯Ό μ ννμμμ€. `standalone`μ μΌλ°μ μΌλ‘ μ νΈλλ μ΅μ μ λλ€.
- λ§€λνμ€νΈ μ ν¨μ± κ²μ¬: `manifest.json` νμΌμ΄ μ¬λ°λ₯΄κ² νμμ΄ μ§μ λμλμ§ νμΈνκΈ° μν΄ νμ μ ν¨μ±μ κ²μ¬νμμμ€.
- PWA ν μ€νΈ: λ€λ₯Έ λΈλΌμ°μ μ μ₯μΉμμ PWAλ₯Ό ν μ€νΈνμ¬ μμλλ‘ μλνλμ§ νμΈνμμμ€.
- SEO μ΅μ ν: μ±μ κ²μ κ°λ₯μ±μ κ°μ νκΈ° μν΄ `name`, `short_name`, `description`μ κ΄λ ¨ ν€μλλ₯Ό μ¬μ©νμμμ€.
- νμ§ν κ³ λ €: μ±μ΄ μ μΈκ³ μ¬μ©μλ₯Ό λμμΌλ‘ νλ κ²½μ° λ€λ₯Έ μΈμ΄μ λν λ€λ₯Έ μ΄λ¦, μ€λͺ λ° μμ΄μ½μΌλ‘ λ§€λνμ€νΈμ νμ§νλ λ²μ μ μ 곡νλ κ²μ κ³ λ €νμμμ€.
μ ꡬμ±λ μΉ μ± λ§€λνμ€νΈ μμ
λ€μμ μΈκΈ° μλ PWAμ μ ꡬμ±λ μΉ μ± λ§€λνμ€νΈ λͺ κ°μ§ μμ λλ€:
Twitter Lite
{
"name": "Twitter Lite",
"short_name": "Twitter",
"icons": [
{
"src": "/static/icons/mstile-150x150.png",
"sizes": "150x150",
"type": "image/png"
},
{
"src": "/static/icons/twitter-192x192.png",
"sizes": "192x192",
"type": "image/png"
},
{
"src": "/static/icons/twitter-512x512.png",
"sizes": "512x512",
"type": "image/png"
}
],
"start_url": "/",
"display": "standalone",
"background_color": "#ffffff",
"theme_color": "#1da1f2",
"description": "Twitter Lite is a faster, data-friendly way to see what's happening in the world.",
"orientation": "portrait"
}
Starbucks
{
"name": "Starbucks",
"short_name": "Starbucks",
"icons": [
{
"src": "/static/icons/starbucks-icon-192x192.png",
"sizes": "192x192",
"type": "image/png"
},
{
"src": "/static/icons/starbucks-icon-512x512.png",
"sizes": "512x512",
"type": "image/png"
}
],
"start_url": "/",
"display": "standalone",
"background_color": "#f2f0eb",
"theme_color": "#00704a",
"description": "Order your favorite Starbucks drinks and food with the app.",
"orientation": "portrait",
"shortcuts": [
{
"name": "Order Now",
"short_name": "Order",
"description": "Start a new order",
"url": "/order",
"icons": [{
"src": "/static/icons/order-icon.png",
"sizes": "192x192",
"type": "image/png"
}]
}
]
}
μΉ μ± λ§€λνμ€νΈμ λ―Έλ
μΉ μ± λ§€λνμ€νΈλ μ§ννλ νμ€μ΄λ©° μκ°μ΄ μ§λ¨μ λ°λΌ μλ‘μ΄ κΈ°λ₯κ³Ό κΈ°λ₯μ΄ μΆκ°λκ³ μμ΅λλ€. PWAκ° μ΅μ κΈ°μ μ μ΅λν νμ©νλλ‘ W3Cμ μ΅μ μ λ°μ΄νΈ λ° κΆμ₯ μ¬νμ κ³μ μ£Όμνμμμ€.
κ²°λ‘
μΉ μ± λ§€λνμ€νΈλ λͺ¨λ PWAμ νμ κ΅¬μ± μμμ λλ€. λ§€λνμ€νΈλ₯Ό μ¬λ°λ₯΄κ² ꡬμ±νλ©΄ μννκ³ λ§€λ ₯μ μΈ μ¬μ©μ κ²½νμ μ 곡νμ¬ μΉ μ±μ λ€μ΄ν°λΈ μ ν리μΌμ΄μ μ²λΌ λλΌκ² ν μ μμ΅λλ€. μ΄ κ°μ΄λμμλ λ§€λνμ€νΈ μμ±, λͺ¨λ² μ¬λ‘ λ° μμλ₯Ό ν¬ν¨νμ¬ μΉ μ± λ§€λνμ€νΈμ λν ν¬κ΄μ μΈ κ°μλ₯Ό μ 곡νμ΅λλ€. μ΄λ¬ν μ§μΉ¨μ λ°λ₯΄λ©΄ PWAμ μ μ¬λ ₯μ μ΅λν λ°ννκ³ μ μΈκ³ μ¬μ©μμκ² λ λμ μ¬μ©μ κ²½νμ μ 곡ν μ μμ΅λλ€.
μΉ μ± λ§€λνμ€νΈμ νμ νμ©νκ³ μΉμ¬μ΄νΈλ₯Ό μ€μΉ κ°λ₯νκ³ μ±κ³Ό κ°μ κ²½νμΌλ‘ λ³ννμ¬ μ¬μ©μλ₯Ό κΈ°μκ² νκ³ μ°Έμ¬λ₯Ό μ λνμμμ€.