Menu

manifest.json

Web Manifest仕様に準拠する manifest.(json|webmanifest) ファイルを app ディレクトリのルートに追加または生成し、ブラウザにWebアプリケーションに関する情報を提供します。

静的マニフェストファイル

app/manifest.json
{
  "name": "My Next.js Application",
  "short_name": "Next.js App",
  "description": "Next.jsで構築されたアプリケーション",
  "start_url": "/"
  // ...
}

マニフェストファイルの生成

Manifestオブジェクトを返す manifest.js または manifest.ts ファイルを追加します。

補足: manifest.js は特別なルートハンドラで、動的APIまたは動的構成オプションを使用しない限り、デフォルトでキャッシュされます。

app/manifest.ts
import type { MetadataRoute } from 'next'
 
export default function manifest(): MetadataRoute.Manifest {
  return {
    name: 'Next.js App',
    short_name: 'Next.js App',
    description: 'Next.js App',
    start_url: '/',
    display: 'standalone',
    background_color: '#fff',
    theme_color: '#fff',
    icons: [
      {
        src: '/favicon.ico',
        sizes: 'any',
        type: 'image/x-icon',
      },
    ],
  }
}
app/manifest.js
export default function manifest() {
  return {
    name: 'Next.js App',
    short_name: 'Next.js App',
    description: 'Next.js App',
    start_url: '/',
    display: 'standalone',
    background_color: '#fff',
    theme_color: '#fff',
    icons: [
      {
        src: '/favicon.ico',
        sizes: 'any',
        type: 'image/x-icon',
      },
    ],
  }
}

マニフェストオブジェクト

マニフェストオブジェクトには、新しいWeb標準により更新される可能性のある広範なオプションが含まれています。現在のすべてのオプションについては、TypeScriptを使用している場合はコードエディタで MetadataRoute.Manifest 型を参照するか、MDNのドキュメントを参照してください。